【问题标题】:How do I include HTML in a JS Rails response?如何在 JS Rails 响应中包含 HTML?
【发布时间】:2010-09-22 23:09:08
【问题描述】:

我有一个响应 HTML 和 JS (AJAX) 查询的 FooController:

# app/controllers/foo_controller.rb:
class FooController < ApplicationController
  layout 'foo'
  def bar
    respond_to do |format|
      format.html # foo/bar.html.erb
      format.js   # foo/bar.js.erb
    end
  end
end

支持它的模板:

# app/views/layouts/foo.html.erb:
<html>...<%= yield %>...</html>

# app/views/layouts/foo.json.erb:
<%= yield %>

还有一个我想在其中呈现部分内容的 AJAX 模板:

# app/views/foo/bar.js.erb:
dojo.byID('some_div').innerHTML = "<%= escape_javascript(render(:partial => 'some/partial')) %>";

如果 JS 模板中只有普通的旧 JS(如 alert('hi');),它会使用我的 JS 模板。但是,当我放入 render(:partial) 时,它会使整个响应使用 HTML 模板,这意味着它不再是有效的 JS。

一种可能的解决方案是使用函数进行布局:

class FooController < ApplicationController
  layout :choose_layout
  ...
  private
  def choose_layout
    return nil if request.xhr?
    'foo'
  end
end

但我的版本应该工作!为什么不呢?

【问题讨论】:

  • 我认为它不起作用的原因是一个小错误:我有一个 .json.erb 模板,但没有 .js.erb 模板,也没有默认的 .erb 模板。

标签: javascript ruby-on-rails ruby erb


【解决方案1】:

最近的Railscast covers this topic (using jQuery)

我不太明白你可能哪里出错了,但这里有一个来自 Railscast 的片段,它可以很好地渲染部分:

// views/reviews/create.js.erb
$("#new_review").before('<div id="flash_notice"><%= escape_javascript(flash.delete(:notice)) %></div>');
$("#reviews_count").html("<%= pluralize(@review.product.reviews.count, 'Review') %>");
$("#reviews").append("<%= escape_javascript(render(:partial => @review)) %>");
$("#new_review")[0].reset();

您将 Javascript 存储在哪里?你有一个 Application.js 来保存东西吗?如果是这样,您是否在 javascript_include_tag 中的“应用程序”之前包含“dojo”?

【讨论】:

    【解决方案2】:

    试试下面的;

    class FooController < ApplicationController
      layout 'foo'
      def bar
        respond_to do |format|
          format.html
          format.js { render :layout => false }
        end
      end
    end
    

    希望对您有所帮助。

    J.K.

    【讨论】:

      猜你喜欢
      • 2011-05-19
      • 2011-09-20
      • 2011-05-05
      • 1970-01-01
      • 2013-10-09
      • 2015-02-12
      • 1970-01-01
      • 2013-09-08
      • 1970-01-01
      相关资源
      最近更新 更多