如何在JS Rails响应中包含HTML?

时间:2008-11-18 23:08:46

标签: javascript ruby-on-rails ruby erb

我有一个响应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

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

2 个答案:

答案 0 :(得分:7)

最新Railscast covers this topic (using jQuery)

我不太明白你可能会出错的地方,但这里有一个来自Railscast的snippit可以很好地呈现部分:

// 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”?

答案 1 :(得分:1)

尝试以下方法;

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

希望有所帮助。

J.K。