初めて質問させていただきます。
前提・実現したいこと
-
Ruby on Rails 5でWebアプリケーションを開発しています。フロントエンドはCoffeescript + jQuery + HTML5です。
-
1枚の画面上にテーブルと、その1レコードに紐づく詳細情報が表示されるような画面構成です。
-
選択中のテーブル1レコードをカレント行とし、マウスクリックやキーイベントをトリガーにカレント行が移り、Ajaxで詳細情報を取得する仕組みです。
発生している問題
-
数行離れたレコードにカレント行を移すため、上下方向キーを連打すると全てのレコードに対して「律儀に」Ajaxリクエストが走ります。
-
通過するレコードによるAjaxリクエストの処理は走らせず、目的のレコードによるリクエストのみ処理させたいです。
-
「試したこと」に後述しますが、一定時間リクエストを待機する方法は試して、近いことは実現できました。他に方法がないかをご教示いただければ幸いです。
該当のソースコード
View層
HTML
1<table> 2 <thead> 3 <tr> 4 <th>code</th> 5 <th>fruit</th> 6 </tr> 7 </thead> 8 <tbody> 9 <tr class='table-row'> 10 <td>1</td> 11 <td>apple</td> 12 </tr> 13 <tr class='table-row'> 14 <td>2</td> 15 <td>orange</td> 16 </tr> 17 <tr class='table-row'> 18 <td>3</td> 19 <td>grape</td> 20 </tr> 21 ... 22 </tbody> 23</table> 24 25<div id='results'> 26 //ここに詳細情報を表示する 27</div>
イベントハンドラ
coffeescript
1$(window).on 'keydown', (event) -> 2 c = if event.which then event.which else event.keyCode 3 if $(document.activeElement).hasClass('table-row') 4 # 押されたキーが上下方向キーのいずれか 5 if c == 38 || c == 40 6 request_ajax() 7 return 8 return
Ajax処理を投げる関数
coffeescript
1request_ajax = -> 2 'use strict' 3 4 # クエリパラメータとしてカレント行のcodeをつけて投げる 5 url_path = '...' 6 7 $.ajax({ 8 url: url_path, 9 type: 'GET', 10 cache: false, 11 dataType: 'html' 12 }).done (html) -> 13 $("#results").append html 14 # 処理
試したこと
-
トリガーとなるイベントをkeyupに変更する
→キーを押しっぱなしにしたときに1行1行処理される状況は回避できますが、連打に対応できません。 -
一定時間リクエストを投げるのを待機して、待機中に次のキーイベントが発火すると待機中のリクエストをキャンセルする
ソースコードは次の通りです。イベントハンドラを次のように書き換えました。
coffeescript
1key_interval = 500 2 3$(window).on 'keydown', (event) -> 4 c = if event.which then event.which else event.keyCode 5 if $(document.activeElement).hasClass('table-row') 6 # 押されたキーが上下方向キーのいずれか 7 if c == 38 || c == 40 8 # 前回のキーイベントによる待機リクエストをキャンセルする 9 clearTimeout(last_timer_id) 10 # Ajaxリクエストを予約 11 timer = setTimeout(request_ajax, key_interval) 12 # 次回のリクエストのためにタイマーIDを保持しておく 13 last_timer_id = timer 14 return 15 return
→結局リクエストを投げるのを一瞬遅らせることになります。不要なリクエストを除去するために目的のリクエストの実行を遅らせるのはあまり上手なやり方ではないように思われます。
わざわざ実行を遅延させなくても済むような、よりよい方法はないでしょうか、という趣旨の質問です。足りない情報などあれば可能な限り補足します。よろしくお願いします。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。