我有一个响应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
但我的版应该工作!为什么不呢?
答案 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。