勉強したことのメモ

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

  関連記事

tableのフィルター機能

jQueryのプラグインで簡単にフィルター機能が つけられたのでメモ。 ■必要な ...

Ajaxで負荷軽減

業務中、専用のページでfile_get_contents的なものは あまり使わな ...

jQueryでボタンをクリックしてクリップボードにコピー

■2015/11/01追記 以下記事でライブラリとか無しで同様の機能がつけられる ...

chardin.jsを利用して注釈を入れる

簡易マニュアルとかでむっちゃ使えそう。 ■chardin.js http://h ...

FormDataを使ったAjax通信がiPhoneのみエラー

FormDataオブジェクトを使用したAjax通信するシステムがあり、PCやAn ...

jQueryでドロワーメニューの作成

■やりたかった事 スマホ用サイトにドロワーメニューを設置したかった。 &nbsp ...

スクロールしてもついてくる追尾型の広告を作る方法

スマホサイトとかでよく見る、スクロールしてもページ下部とかに常時表示されている追 ...

プラグインを使用せず、jQueryでオートページャー

プラグインを使わずにオートページャーを 作りたかった。 内容としては、 ・ターゲ ...

jQueryの最新バージョン呼び出しとバージョン確認

<script type="text/javascript" src="h ...

FullCalendarでtitle以外も表示させたい

FullCalendarでカレンダー内のイベントをクリックした際にtitle以外 ...