質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
CoffeeScript

CoffeeScriptはプログラミング言語です。シンタックスシュガーの導入により、JavaScriptのコードに変換された後動作します。JavaScriptに比べ、可読性と簡潔性が向上しています。

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

4614閲覧

連続したキーイベントによる不要なAjaxリクエストを間引きたい

umaria333

総合スコア7

CoffeeScript

CoffeeScriptはプログラミング言語です。シンタックスシュガーの導入により、JavaScriptのコードに変換された後動作します。JavaScriptに比べ、可読性と簡潔性が向上しています。

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2018/06/01 10:34

初めて質問させていただきます。

前提・実現したいこと

  • 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
→結局リクエストを投げるのを一瞬遅らせることになります。不要なリクエストを除去するために目的のリクエストの実行を遅らせるのはあまり上手なやり方ではないように思われます。

わざわざ実行を遅延させなくても済むような、よりよい方法はないでしょうか、という趣旨の質問です。足りない情報などあれば可能な限り補足します。よろしくお願いします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

「キーボード操作でフォーカスを変え、フォーカスがあたったらajaxでデータをフェッチする」ということが機能として正しいのであれば、その方法で間違いない気がします。ユーザがキーボードを連打しても、一度打っても、押しっぱなしにしても同じ結果にするにはそういった実装が必要になるでしょう。

その上で、APIへのリクエスト負荷を減らしたいのであれば、キーボードでの操作を機能からはずしてマウスやタップでのクリック時に同様のことを実装したり、あるいはそもそもAPI側で詳細情報も含めたHTMLをレンダリングするなどの方法が考えられます。

もしくは、「律儀に」すべてAjaxを実行することもありえない選択肢ではないように思います。Google検索のインクリメンタルサーチなどはそういった実装になっているはずですので。

サーバーの負荷とクライアントの実装工数とアプリケーションの利便性のバランスをとったより富豪的な選択を検討ください。

投稿2018/06/01 16:03

keroxp

総合スコア114

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問