link_to和remote => true + jquery:怎么样? 救命?
我试图在我的rails网站的索引上建立一个“用户”链接,以便它显示注册用户(User.all)但我希望它出现在网站的右侧部分,作为部分,在没有div从头开始加载整个页面。
我知道这可能是旧的原型和远程=>真,但使用Rails 3.1和jQuery(和资产)我不知道如何做到这一点。
任何人都可以帮助或告诉我教程的方法吗?
它实际上非常简单,只是感觉很重要,因为它是新的。 基本上,通过新的不显眼的javascript支持,rails ujs脚本公开了一组可以绑定javascript函数的事件,它们是:
- ajax:beforeSend – 在发送之前触发
- ajax:success – 发送后触发,包含响应
- ajax:完成 – 在成功事件后被解雇
- ajax:错误 – 出现错误时触发
你需要做的就是编写一个函数(你在$ document.ready中包装),然后将一些匿名函数绑定到每个事件,或者只是你感兴趣的事件。
例如,假设您有一个div,您希望将响应数据放入id为“response_data”,并且您有一个id为“ajax_trigger”的链接。 像这样的东西:
<%= link_to "My Link", some_model_path(@model_instance), :remote => true, :html => {:id => "ajax_trigger"} %>
您需要做的就是提供类似下面的function,以便将服务器的响应放入div中:
$(document).ready( function(){ $("a#ajax_trigger").bind("ajax:success", function(evt, data, status, xhr){ //this assumes the action returns an HTML snippet $("div#response_data").html(data); }).bind("ajax:error", function(evt, data, status, xhr){ //do something with the error here $("div#errors p").text(data); }); });
实际上,您使用javascript所做的就是在从服务器返回时处理响应。 您并不需要做任何特殊的事情来启动XHR请求,您也可以安全地将此方法存储在作为静态资产提供的.js文件中。 如果您使用的是Rails 3.1,那么您应该将它放在与控制器对应的适当命名的javascript文件中。 在您的控制器中,您需要确保在responds_with()方法中指定:layout => false,这样控制器只返回它呈现的部分或模板,而不是完整的页面。 此设置也适用于返回由客户端和JSON执行的javascript的操作,具体取决于您在请求中指定的数据类型。
我发现这篇博文非常有帮助: http : //www.alfajango.com/blog/rails-3-remote-links-and-forms/
以下是有用资源列表:
- Rails 3远程链接和表单:权威指南
- Rails link_to文档
- Rails中不引人注目的JavaScript助手3