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

我有一个响应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: ...... # app/views/layouts/foo.json.erb:  

还有一个我要渲染部分的AJAX模板:

 # app/views/foo/bar.js.erb: dojo.byID('some_div').innerHTML = " '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 

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

最新的Railscast涵盖了这个主题(使用jQuery) 。

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

 // views/reviews/create.js.erb $("#new_review").before('
<%= escape_javascript(flash.delete(:notice)) %>
'); $("#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”?

尝试以下方法;

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

希望有所帮助。

JK