我在视图中有以下 javascript:
<script type="text/javascript">
var pusher = new Pusher('<%= Pusher.key %>'); // Replace with your app key
var channel = pusher.subscribe('choices');
channel.bind('created', function(data) {
var after = $('.ticket:last').attr('data-time');
$("#tickets").append("<%=raw escape_javascript(render(@tickets, :after => " + after + ")) %>");
});
</script>
我的控制器中有以下内容:
@tickets = Choice.where("choices.created_at > ?", Time.at(params[:after].to_i + 1).utc)
我正在寻找一种将after参数从 javascript 传递到控制器的方法,例如它只返回 created_at 高于现在显示的最后一个选项的选项。
我猜这条线没有做这项工作,所以对此有一点帮助会非常有用:)
$("#tickets").append("<%=raw escape_javascript(render(@tickets, :after => " + after + ")) %>");
编辑:
我现在有以下内容,这似乎修复了将after变量传递给控制器的问题。我检查了 Firebug,可以看到响应包含最新 BET 上的数据。但视图仍然是错误的。它不会将最新的投注附加到 DIV,而是显示所有过去的投注两次,而根本没有新的投注。任何人?:)
查看文件:
<script type="text/javascript">
var pusher = new Pusher('<%= Pusher.key %>'); // Replace with your app key
var channel = pusher.subscribe('choices');
channel.bind('created', function(data) {
var after = $('.ticket:last').attr('data-time');
var settings = { after: after}
$.ajax({
url: '/Home/Index',
type: 'POST',
dataType: 'json',
data: settings,
cache: true,
success: function (data) {
$("#tickets").append("<%=raw escape_javascript(render(@tickets)) %>");
}
});
}
);
</script>
路线:
post 'Home/Index' => 'home#index'
控制器(索引操作):
@tickets = Choice.betable(current_user).where("choices.created_at > ?", Time.at(params[:after].to_i + 1).utc)
respond_to do |format|
format.json { render :json => @tickets }
format.html
end
解决方案:
经过大量试验和错误后,我最终使用了一个解决方案,在控制器中呈现 HTML,而不是在视图中的 javescript 代码中呈现。这样我就可以访问我需要的参数。
respond_to do |format|
format.html
format.json do
@html = render_to_string( :partial => '/choices/choice.html.erb', :locals => { :choice => @tickets} )
render :json => { :success => true, :html => @html }
end
end
感谢 Chazt3n 的扩展帮助 :) 真的很高兴..