我正在使用带有jQuery的Rails3并尝试执行简单的ajax调用。我有一个链接,显示应用程序的当前状态(在线/离线)。单击时,它将更新状态。
link_to app.status, { :controller => :apps, :action => :live_status, :id => app }, {:remote => true, :class => "#{app.status} status"}
live_status.js.erb:
$(this).fadeOut();
$(this).parent().html("<%= escape_javascript(status_link(@wowza_app)) %>");
$(this).fadeIn();
status_link将返回更新的link_to
然而$(这个)并不是我想象的那样。如何使用新状态更新点击状态?
答案 0 :(得分:8)
你应该给你想要更新ID的元素(我在最后添加了一个元素到哈希):
link_to app.status, { :controller => :apps, :action => :live_status, :id => app }, {:remote => true, :class => "#{app.status} status", :id => app.id}
现在,您可以使用相同的标识符通过jQuery选择正确的元素:
$("#<%= @wowza_app.id %>").fadeOut();
$("#<%= @wowza_app.id %>").parent().html("<%= escape_javascript(status_link(@wowza_app)) %>");
$("#<%= @wowza_app.id %>").fadeIn();
当然,这假设@wowza_app
有一个名为id
的方法返回相同的链接ID,但您可以根据需要修改变量以选择具有正确ID的元素。 / p>
答案 1 :(得分:3)
你应该使用选择器。当您在ajax响应中解释了该代码时,jQuery不知道您指的是什么“this”。更好地使用类似的东西:
$('#my-special-div').fadeOut();
$('#my-special-div').parent().html("<%= escape_javascript(status_link(@wowza_app)) %>");
$('#my-special-div').fadeIn();
$('#my-special-div').hide(2000, function () {
$(this).remove(); // here jQuery knows you are talking about 'my-special-div'
});