勉強したことのメモ

webプログラマ見習いが勉強したことのメモ。

Ajaxの負荷対策

      2014/07/03

Ajaxを使ってボタンを押した際に表示を切り替える処理。
都度Ajaxを使ってたんだけど、それだとサーバーに負荷が
かかるとのご指摘で、その対処法。

-----------
Ajaxでカンマ区切りの文字列を取得
↓↓
受け取ってカンマ取り外して配列化
↓↓
配列から一つずつ取り出す。取り出した分配列から削除
↓↓
無くなったら冒頭に戻る
-----------

というもので、DBへの接続を極力減らす。

$(function(){

//変数を宣言。グローバル変数として使えるようにする。
var name_js = "";
var name_array = "";

//Ajax部分を関数化
function name_ajax(){
$.ajax({
dataType : "jsonp",
url: "https://aaa/bbb/ccc/index.php",
success: function(msg){
if(msg){
//文字列を変数に入れる
name_js = msg;
//文字列をカンマを取って配列化
name_array = name_js.split(",");
//配列の一番最初の値を取り出す
$("#name").val(name_array[0]);
                    //取り出したところを配列から排除する
name_array.splice(0, 1);
}
}
});
}

    //ページ読み込み時にAjaxを使用
name_ajax();

    //マウスボタンを押した際に処理
$("#name_change").mousedown(function(){
        //配列の中身が0の場合の処理
if (name_array.length == 0) {
            //Ajaxの関数を呼び出して配列取得
name_ajax();
        //配列の中身がある場合の処理
} else {
            //配列の一番最初の値を取り出す
            $("#name").val(name_array[0]);
            //取り出したところを配列から排除する
name_array.splice(0, 1);
}
});
});

値取り出し、配列から排除を2回書いているので、

もうちょっとスマートに出来そう。

 - Ajax, jQuery

  関連記事

jquery_logo
jQueryのCSS変更

jQueryでCSSを触る際、 $("#aaa").css('height',' ...

jquery_logo
jQueryで後から追加された要素にイベントを設定

jQueryで.html()等を使って追加した要素に対してイベントを設定したかっ ...

jquery_logo
Ajaxでボタンとテキストボックス操作

ボタンを押して「https://aaa/bbb/ajax.php」からの 返答を ...

jquery_logo
jQueryでチェックボックスの全チェック&チェック解除

フォームのチェックボックスで「全てにチェックを入れる」「全てのチェックを外す」と ...

jquery_logo
jQueryで画像(タグ内)のsrc情報を取得する場合

すぐに出てこなかったのでメモ。 $('#test').attr('src'); ...

jquery_logo
画像の登録フォームにてjQueryプラグインを用いてWebカメラの映像を撮影させる方法

form内の画像アップロード部分にて、通常であれば画像ファイルを参照させたものを ...

jquery_logo
jQuery2.0がリリース

リリースされたとのこと。 http://blog.jquery.com/2013 ...

jquery_logo
Ajaxで画像のアップロード(jquery.upload)

業務中に画像の選択後、アップロードボタンを押して画像のアップ、 その後フォームの ...

jquery_logo
Ajaxでプラグイン無しのファイルアップロード

画像ファイルを添付できて、尚且つAjaxを用いた非同期通信のフォームを作りたかっ ...

jquery_logo
jQueryでshow/hideよりaddClass/removeClassの方が速い

diaplay:none/blockする際に最近はshow()/hide()を ...