jQueryで別ドメイン間のAjax通信を行う

Ajax通信ってそんなに使うことあるのかな?

って思いますが、使えたら使えたで便利なのです。

通常Webページの画面の内容を更新するには画面全体が再表示されますが、Ajaxを使うことで画面の一部だけを更新することが出来ます。

Google Map をページに埋め込んでいると、地図だけは動きますが他の部分は書き換わりませんよね。
また、住所入力フォームなどで郵便番号を入れてボタンをクリックすると住所がでてきませんか?

このような場所ではAjaxによる通信が行われて一部のデータだけを更新しています。

そんな便利なAjax通信が行えるようになりましょう。

 

 

実装例

クライアント : 計算フォームを表示、Ajaxでサーバプログラムを呼び出す
サーバ : Ajaxで呼び出される計算プログラムを置いておく

 

 

サーバ側

クライアントからPOSTされてきたデータを受け取り、処理を行った後にクライアントに返す

クライアントからPOSTされてきた、val1、val2の値を足してその結果を返しています。

 

クライアント側

val1, val2 をnameに持つフォームを用意し、ボタンを1つ設置します。
ボタンのタイプは button にしておいてください。
submit にしてしまうと自画面に送信します。

当然のことながらサーバ側の処理は呼ばれません。

結果を受ける所を .then で記述しております。

第1引数に成功時のメソッドを、第2引数に失敗時のメソッドを渡します。

 

 

まとめ

上記では、通信の結果部分の記述に .then を使いましたが、以前は下記のように success を使った書き方をしていました。

 

どちらでも問題ないとは思いますが、古い書き方はサポートされなくなる可能性があるので、新しい書き方をしたほうがいいかもしれませんね。

 

コメントを残す

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です