勉強したことのメモ

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

Ajaxの負荷対策

   

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回書いているので、

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

 - jQuery, Ajax

  関連記事

配列をjQueryで取り扱う

やりたかった事は、 ・テキストボックスが複数ある。そのページに送信するクエリによ ...

jQueryでIPから位置情報の取得

jQueryのプラグインでお手軽にIPから 位置情報や経度緯度等調べられたのでメ ...

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

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

formでファイルを選択した際にファイル名やサイズ、形式を調べる方法

フォームで画像などをアップロードする際に「ファイルサイズが大きすぎないか?」「拡 ...

jQueryで要素のleftやwidthを取得

jQueryで要素のposition(leftやtop)とwidthとheigh ...

pjaxについてのメモ

ずっと気になっていたpjaxについてのメモ。 ■参考サイト http://chi ...

jQuery2.0がリリース

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

jQueryでformの各種パーツ(テキストボックス等)の操作まとめ

jQueryでフォームのセレクトメニューやラジオボタン等、各種パーツを操作するこ ...

jQueryでコンテンツのスライド

jQueryもしくはJavaScriptでリンクを押すと 右から左にコンテンツを ...

JavaScriptで数値のカウントアップ及びカウントダウン

JavaScript(一部jQuery)で数値のカウントアップ及びカウントダウン ...