Jam*_*sen 14 javascript ruby ruby-on-rails 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
Run Code Online (Sandbox Code Playgroud)
支持它的模板:
# app/views/layouts/foo.html.erb:
<html>...<%= yield %>...</html>
# app/views/layouts/foo.json.erb:
<%= yield %>
Run Code Online (Sandbox Code Playgroud)
还有一个我要渲染部分的AJAX模板:
# app/views/foo/bar.js.erb:
dojo.byID('some_div').innerHTML = "<%= escape_javascript(render(:partial => 'some/partial')) %>";
Run Code Online (Sandbox Code Playgroud)
如果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
Run Code Online (Sandbox Code Playgroud)
但我的版本应该工作!为什么不呢?
最新的Railscast涵盖了这个主题(使用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();
Run Code Online (Sandbox Code Playgroud)
你在哪里存储你的Javascript?你有一个Application.js,你有什么东西?如果是这样,你在javascript_include_tag中的"应用程序"之前是否包含"dojo"?
| 归档时间: |
|
| 查看次数: |
13166 次 |
| 最近记录: |