を入力し終え、これは私が探しています何でも可能である場合、私は疑問に思って:Ajaxは
Exercise | Reps | Lbs | Kg
-------------------------------------
Squat | 8 | 135 | 61.23
Squat | 8 | 225 | 102.06
Squat | 6 | 315 | 142.88
Squat | 2 | 405 | 183.70
Squat | 1 | 485 | 219.99
:
また、私はこのようになりますフォームでテーブルを持っています'Reps'、 'Lbs'、 'Kg'の値はすべて編集可能です。
私はこれに問題が発生しています。 1回のキーアップイベントごとにajaxリクエストを送信したくないので、サブミットボタンも必要ありません。私はタイマーを実装しているので、ユーザが2秒間(または長時間)タイピングをやめると更新されます。しかし、私が実行している問題は、このタイマーを別の行に分けることができないことです。私は説明しましょう:
もし上の行を135lbsで編集すると、それはすぐに適切にKgを更新します& & 2)カウントダウンタイマーを開始します。
次に225lbsで次の行を編集すると、最初の行が更新されないことを意味するタイマーが開始されます。
潜在的な解決策は、新しい編集ごとにタイマーを開始することですが、最終的に終了したらすべてを更新することです。しかし、これは私の数や行が技術的には無限の量になるかもしれないので、それは無駄かもしれないようです。
変更されたクラスにクラスを追加することを考えましたが、それらのクラスのみを更新します...しかし、それらを更新して元に戻った場合、更新する必要があります。
これにアプローチする方法についてのご意見はありますか?
入力の焦点が変わったときに、私はちょうど考えていたと思っています。これにより、ユーザーは必要なだけ入力することができます。また、別の入力に移動すると、元のものが更新されます。私は他の提案のために開いています。 –
両方の方法はありますか?ユーザーが2秒間入力して一時停止すると、ajax呼び出しが行われます。フォーカスが入力から離れる場合は、ajax呼び出しを行い、タイマーをキャンセルします。そうすれば、一度に最大1つのタイマーしか持たないでしょう。 –
それは本当です...両方を行うことができます。数秒待ってから別の変更を加えることなく入力を終了しても、サーバーへの余分な呼び出しかもしれませんが、良い解決策になるかもしれません。 –