2016-04-30 10 views
2

問題を説明する前に、関連するコードを文脈で提供します。私はスコアボードモデルに関連付けられているチームモデルを持っています。手元の問題はチームに関連しています。 @用Ajax "link_to"本当に高速にクリックされたときに複数のリクエストコントローラリクエストを送信する(Rails 4)

<div class="team-list"> 
    <%= render @scoreboard.teams.reject(&:new_record?) %> 
</div> 

部分チーム指数ため

ビュー

<div class="row team-div" id="team_<%=team.id%>"> 
    <div class="col-xs-3 team-div-1"> <%= team.name %> </div> 

    <%= link_to (edit_scoreboard_team_path(@scoreboard, team)), remote: true do %> 
     <div class="col-xs-6 team-data"> 
     <div class="row"> 
      <div class="col-xs-4 team-div-2"><%= team.win %> </div> 
      <div class="col-xs-4 team-div-2"><%= team.loss %> </div> 
      <div class="col-xs-4 team-div-2"><%= team.tie %></div> 
     </div> 
     </div> 
    <% end %> 

    <div class="col-xs-1 team-div-2"> 
     <%= team.win + team.loss + team.tie %> 
    </div> 

    <div class="col-xs-1 team-div-2"> 
     <% total_games = team.win.to_i + team.loss.to_i + team.tie.to_i %> 
    <% if total_games == 0 %> 
    <%= "N/A" %> 
    <% else %> 
    <%= (team.win.to_i/(total_games).to_f*100).round(2) %><%="%"%> 
    <% end %> 
    </div> 

    <div class="col-xs-1 team-setting"> 
      <i class="fa fa-trash-o fa-lg" aria-hidden="true"></i> 
    </div> 

</div> 

scoreboard.teams私はとのトラブルを抱えているのlink_toは編集方法ためです。

チーム#編集コントローラメソッド

def edit 
    @scoreboard = Scoreboard.find(params[:scoreboard_id]) 
    @team = @scoreboard.teams.find(params[:id]) 
    respond_to do |format| 
    format.html {redirect_to scoreboard_url(@team.scoreboard_id)} 
    format.js 
    end 
    end 

edit.js.erbファイル

$("#team_<%[email protected]%>").hide(); 
$("#team_<%[email protected]%>").before("<%= j render 'teamedit'%>"); 

、problem.Iは、開発環境で午前説明します。完璧な世界では、編集のためにlink_toをクリックして、特定のチーム部門をすぐに消滅させて(私は再びそれをクリックすることはできません)、そのチームの編集フォームをレンダリングします。しかし、低速のロード(多くの場合)ではlink_toを2,3回クリックすることができ、複数のコントローラ要求を編集メソッドに呼び出します。これの問題は、Jqueryもクリックした回数だけ実行され、同じ要素に対して2〜3つのフォームが完成することです。

I = 50 IDを持つチームのためのlink_toに本当に速いクリックしたときにたとえば、これらのログファイルです:

Started GET "/scoreboards/1/teams/50/edit" for 99.239.140.167 at 2016-04-30 08:07:52 +0000 
Processing by TeamsController#edit as JS 
    Parameters: {"scoreboard_id"=>"1", "id"=>"50"} 
    User Load (0.6ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 LIMIT 1 [["id", 1]] 
    Scoreboard Load (0.3ms) SELECT "scoreboards".* FROM "scoreboards" WHERE "scoreboards"."id" = $1 ORDER BY "score oards"."created_at" DESC LIMIT 1 [["id", 1]] 
    Team Load (0.3ms) SELECT "teams".* FROM "teams" WHERE "teams"."scoreboard_id" = $1 AND "teams"."id" = $2 LIMIT 1 [["scoreboard_id", 1], ["id", 50]] 
    Rendered teams/_teamedit.html.erb (3.1ms) 
    Rendered teams/edit.js.erb (7.1ms) 
Completed 200 OK in 35ms (Views: 27.6ms | ActiveRecord: 1.2ms) 


Started GET "/scoreboards/1/teams/50/edit" for 99.239.140.167 at 2016-04-30 08:07:52 +0000 
Processing by TeamsController#edit as JS 
    Parameters: {"scoreboard_id"=>"1", "id"=>"50"} 
    User Load (0.3ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 LIMIT 1 [["id", 1]] 
    Scoreboard Load (0.4ms) SELECT "scoreboards".* FROM "scoreboards" WHERE "scoreboards"."id" = $1 ORDER BY "scoreboards"."created_at" DESC LIMIT 1 [["id", 1]] 
    Team Load (0.3ms) SELECT "teams".* FROM "teams" WHERE "teams"."scoreboard_id" = $1 AND "teams"."id" = $2 LIMIT 1 [["scoreboard_id", 1], ["id", 50]] 
    Rendered teams/_teamedit.html.erb (2.1ms) 
    Rendered teams/edit.js.erb (5.6ms) 
Completed 200 OK in 30ms (Views: 24.2ms | ActiveRecord: 1.0ms) 

edit.js.erbをレンダリング各要求ので、私は2つになってしまいましたフォーム。 リンクが消える前に「link_to」を何回クリックしても、そのリソースの編集フォームは1つしか作成されない可能性がありますか?

答えて

2

jQueryを使用して、最初のクリックでリンクを無効にすることでこれを修正できます。

はリンク

<%= link_to (edit_scoreboard_team_path(@scoreboard, team)), remote: true, class: "team-edit-link" do %> 
    ... 
<% end %> 

無効にそれが

$('.team-edit-link').click(function(e) { 
    if($(this).hasClass('disabled')){ 
    e.preventDefault(); 
    } 
    else{ 
    $(this).addClass('disabled'); 
    } 
}); 
+0

こんにちはをクリックすると、リンクにクラスを追加します!ご回答有難うございます。このコードをedit.js.erbファイルまたはapplication.jsファイルに記述しますか? – kpaul

+0

application.jsまたはそのページ/コントローラに固有のカスタムjsファイルに追加できます。文書準備機能でバインドしていることを確認してください。 – webster

+0

ねえ。ご協力いただきありがとうございます。私は自分のコードを自分で修正しましたが、間違いなく正しいアイデアでした。 – kpaul

関連する問題