Ajax请求触发两次

时间:2011-01-20 21:40:22

标签: ruby-on-rails ajax

我正在铁路上进行ajax调用以更新数据库中的标志。

出于某种原因,请求已完成两次。

日志中2个调用之间的唯一区别是:

Started PUT "/negotiations/groupprocurement_validation_toggle?id=1504" for 127.0.0.1 at 2011-01-20 22:28:39 +0100
Processing by NegotiationsController#groupprocurement_validation_toggle as JS


Started PUT "/negotiations/groupprocurement_validation_toggle?id=1504" for 127.0.0.1 at 2011-01-20 22:28:40 +0100

NegotiationsController处理#grapprocurement_validation_toggle为 /

所以区别在于“as JS”或“as / ”。

我不知道这意味着什么:(

这是链接

 <%= link_to truefalse(validation_status.validated_global, true), validate_global_negotiations_path(:id => validation_status), :method => :put, :remote => true, :id => "validation_#{validation_status.id}" %>

Javascript

 $('a[id^=validation_]').live('click', function(){
        var line_id = $(this).attr('id').replace('validation_','');

        $.ajax({
            url: '/negotiations/gp_validation_toggle?id=' + line_id,
            type: "PUT",
        success: function(data){
          $('#validation_image_' + line_id).html(img_result);
                $('#container').prepend(msg_result)
                $('#flash_notice').delay(3000).fadeOut('slow');
        },
        beforeSend: function(){
          $('#validation_image_' + line_id).html('<img src="/images/loading_round.gif">');
        }
        });
        return false;
    });

在控制器中,我有

respond_to :html, :js, :csv

  def gp_validation_toggle
      @negotiation = Negotiation.find(params[:id])
      @negotiation.validated_global = !@negotiation.validated_global
      if @negotiation.save
        flash[:notice] = "Modification saved"
      else
        flash[:notice] = "Oops something went wrong"
      end
  end

我做错了什么?

感谢, P上。

1 个答案:

答案 0 :(得分:0)

尝试使用委托代替实时