2

我在视图中有以下 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 的扩展帮助 :) 真的很高兴..

4

1 回答 1

1

我相信你可以通过 AJAX 发送它

Function sendAfter((string?) after){
 var settings = { after: after}
 $.ajax({
        url: '/Controller/Action',
        type: 'POST',
        dataType: 'json',
        data: settings,
        cache: true,
        success: function (data) {}
      });
}

这将至少将您的数据传递给控制器​​只需调用该函数并将您的参数发送到您想要的任何地方

于 2012-10-15T21:27:54.090 回答