Web 開発では、フォームの送信は非常に一般的な操作であり、通常、フォームの送信はページを更新することで完了します。ただし、フォームの送信後にページを更新したくない場合はどうすればよいでしょうか?この記事では、jQuery と Ajax を使用して、ページを更新せずにフォーム送信を実装する方法を紹介します。
1. ページを更新してみませんか
従来のフォーム送信プロセスでは、ユーザーはページが更新されるまで辛抱強く待つ必要があり、ユーザー エクスペリエンスが非常に煩雑になります。ページが更新されると、ユーザーは以前に入力したフォームの内容を再入力する必要が生じる可能性があり、ユーザーは不満を感じてしまいます。また、ページ更新により一部のデータが失われる可能性もあり、ユーザーに無用な迷惑を与えることになります。
したがって、Ajax を介してページを更新せずにフォーム送信を実装すると、ユーザー エクスペリエンスが効果的に向上し、ユーザーの時間と労力を節約できます。
2. 実装手順
以下では、次の手順を使用して、ページを更新せずにフォーム送信を実装します。
まず、JavaScript を通じてフォームを送信できるように、フォーム上の送信イベントのリスナー関数をバインドする必要があります。 。同時に、false を返すことでブラウザのデフォルトのフォーム送信動作を防ぐ必要があります。コードは次のとおりです。
$('form').submit(function() { // ajax 表单提交代码... return false; });
次に、jQuery の Serialize() メソッドを通じてフォーム データを取得する必要があります。このメソッドは、後続の Ajax リクエストで使用できるように、フォーム内のすべてのデータを文字列にシリアル化します。コードは次のとおりです。
var formData = $('form').serialize();
ここで、jQuery の ajax() メソッドを通じて非同期リクエストを送信し、フォームを更新せずにフォームを送信する必要があります。ページ。コードは次のとおりです。
$.ajax({ type: 'POST', url: 'submit.php', data: formData, success: function(result) { // 处理返回的数据 } });
この ajax() メソッドでは、次のパラメータを定義します。
type
: リクエストのタイプ。この例では、POST メソッドを選択しました。 url
: リクエストされたターゲット URL。これは、フォームの送信後にデータを送信する PHP ファイルを表す submit.php です。 data
: サーバーに送信されたデータ。以前に取得したフォームデータ、formData を使用しました。 success
: リクエストが成功した後のコールバック関数。この関数では、サーバーから返されたデータをそれに応じて処理できます。 サーバーからデータが返されると、成功コールバック関数でそれを処理できます。たとえば、サーバーから返されたデータをページに表示したり、JavaScript を通じてページのステータスを変更したりできます。コードは次のとおりです。
success: function(result) { // 处理返回的数据: alert(result); $('form')[0].reset(); }
このコールバック関数では、サーバーから返されたデータに対して 2 つの操作を実行します。
これまでのところ、上記の 4 つの手順により、ページを更新せずにフォーム送信を正常に実装できました。
3. 注意事項
Ajax を介したフォーム送信はユーザー エクスペリエンスを大幅に向上させますが、使用中に注意する必要がある点もいくつかあります。 # フォームの繰り返し送信を防止する
$('form').submit(function() { // 禁用按钮 $('input[type="submit"]', this).attr('disabled', 'disabled'); // ajax 表单提交代码... // 启用按钮 $('input[type="submit"]', this).removeAttr('disabled'); });
サーバーから返されたエラーの処理
success: function(result) { if (result.status === 'success') { alert('提交成功'); $('form')[0].reset(); } else if (result.status === 'failed') { alert('提交失败'); } else if (result.status === 'error') { alert('发生了错误:' + result.message); } }
以上がjquery ajaxフォームを送信してもページが更新されませんの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。