Ajaxで今よみがえる(^^;;-->[クロスブラウザ技術 ]DHTMLサンプル集
古籏一浩さんとのはじめての共著 発売中-->『Ajax実践テクニック』 古籏一浩/高橋 登史朗 (著)秀和システム
配本予約開始-->『入門Ajax 増補改訂版 』 高橋 登史朗 (著)ソフトバンククリエイティブ ; ISBN: 4797336242
-- リスト --
【カテゴリー】 ActionScript ( 5 ) AIR ( 2 ) AjaSQL ( 10 ) Ajax ( 561 ) Arax ( 1 ) canvas ( 10 ) CSS ( 10 ) ( 5 ) DLNA ( 1 ) Dojo ( 17 ) DOM ( 45 ) ES4 ( 4 ) 反重力物質 ( 1 ) ffAdd-on ( 1 ) Flash ( 46 ) Flash Remoting ( 11 ) FTP ( 2 ) GAF ( 9 ) Google Maps ( 112 ) GPS ( 41 ) HTTPヘッダサンプル ( 9 ) Internet ( 1 ) IPv6 ( 1 ) 漫画 ( 1 ) Java ( 44 ) JavaScript ( 248 ) jKamo ( 8 ) jQchart ( 1 ) jQuery ( 106 ) jquery-ref ( 1 ) jsGadget ( 19 ) jslb_ ( 3 ) jslb_ajax ( 9 ) JSON ( 46 ) JSR223 ( 7 ) kjscmd ( 1 ) KNOPPIX ( 1 ) Linux ( 15 ) Mac ( 8 ) Memo ( 3 ) Microformats ( 2 ) Mini AJAX ( 2 ) MochiKit ( 2 ) mootools ( 3 ) Movable Type ( 57 ) MySQL ( 10 ) NewGameWeb ( 2 ) Nucleus ( 8 ) OpenAJAX ( 3 ) OpenDocument ( 1 ) OS ( 7 ) P2P ( 2 ) Perl ( 7 ) PHP ( 37 ) PostGIS ( 1 ) PostgreSQL ( 4 ) prototype.js ( 21 ) ROBOT ( 1 ) RSSリーダー ( 14 ) Ruby on Rails ( 7 ) Spry ( 6 ) SQLite ( 11 ) SQLiteWorker ( 2 ) ssh ( 1 ) SSI ( 2 ) SVG ( 15 ) TRON ( 1 ) Video ( 1 ) VML ( 1 ) Webサービス ( 96 ) widget ( 6 ) Wii ( 1 ) Wiki ( 1 ) Win ( 6 ) WSH ( 1 ) X01HT ( 29 ) XML ( 30 ) XOOPS ( 1 ) XQuery ( 2 ) XUL ( 4 ) Yahoo! UI ( 62 ) 日付入力用カレンダー ( 1 ) 『Ajax実践テクニック』 ( 1 ) 『入門 Ajax』 ( 42 ) WinTips ( 2 ) こりゃすごい ( 3 ) チューニング ( 21 ) ダイナミックロード関数 ( 7 ) リファレンス ( 13 ) ライブラリ ( 107 ) レーダー雨量表示 ( 1 ) ハード ( 20 ) ペンギン ( 2 ) ブラウザ ( 71 ) ブログでBBS ( 1 ) アクセスグラフ ( 3 ) イベント ( 1 ) カレンダーによる日付入力スクリプト ( 4 ) クロスブラウザ ( 11 ) クロスブラウザ関数 ( 7 ) スマートフォン ( 8 ) セキュリティ ( 106 ) ソフトイーサ ( 1 ) マッシュアップ ( 23 ) 暗号 ( 4 ) 映画 ( 47 ) 河川の水位グラフ ( 3 ) 回線 ( 2 ) 開発ツール ( 22 ) 牛久大仏 ( 8 ) 携帯 ( 118 ) 言語 ( 18 ) 故障 ( 2 ) 洪水警報システム ( 2 ) 今日のひと言 ( 5 ) 仕様 ( 55 ) 雑談 ( 219 ) 実装 ( 1 ) 書籍 ( 17 ) 親子ウインドウ有無の確認関数 ( 3 ) 新海誠 ( 3 )
【info】有料サポート(ベータ)限定 承り中 多忙につき、一時、新規受付停止 閉店中 /【JSサポート(仮称)】 

【費用】 とりあえず、言い値で承ります。ただし、できる範囲での限定受付です。込み具合等によりお受けできない場合がありますのであらかじめご了承ください。サポートにご納得いただけなければ料金は不要です。 逆に感動したら多くても構いません(^^;;;。

【できること】 たとえば、かも日記で無料配布されているコードのカスタマイズや、あるいは、JavaScript/Ajax全般+Webサーバーとの連携などのアドバイス&サンプル作成等 。A:jQchartなどでWeb用グラフ設置(エクセル→CSVやデータベースからWebグラフ生成)などのアドバイスやカスタマイズサンプル作成。B:ツリーメニューなどのカスタマイズサンプル。C:Google Mapsのカスタマイズ。etc...

【できないこと】 腕立て伏せ200回

【ライセンス】 私が今まで「かも日記」等で提供してきたコードの大半は、商用利用、改造、自由、連絡不要で、今後もそれらは変わりません。そして、この有料サポートによりカスタマイズコードなどが提供される場合でも、同様に、それらを商用利用しても改造しても自由です。ただし、制限のきついライブラリなどを使う場合は、各ライブラリのライセンスに準拠せざるを得ない場合があります。

【info】いつもいろいろなテストなどをページ内のあちこちでやっているので、重かったり、壊れていたりするf^^;ことも多いですが、何卒、ご了承ください ( _ _ b

2005年04月30日

【Ajax】Sync(同期)とAsync(非同期)の体感テスト

Ajax ブックマークに追加する ブックマーク-- Buzzurl  / Hatena  / Livedoor track feed


AjaxのXMLHttpRequest オブジェクトでは、openメソッドの第3引数にturuかfalseを指定して、 Async(非同期通信)かSync(同期通信)かを選ぶことが出来ます。

そこで、Async(非同期通信)とSync(同期通信)はどう違うのか? を体感できるアトラクション、もといページを作ってみました。

  Sync(同期)とAsync(非同期)の体感テスト
  http://jsgt.org/ajax/ref/test/async/test1.htm
  http://jsgt.org/ajax/ref/test/async/test1_1.htm(2005.4.30修正版)

* 連続でリクエストするとresponseTextが1回しか返ってこないので調べたら変数resをローカルにしてなかったのが原因ぽい、、、ということで修正版→test1_1.htm、何度クリックしてもおおむね^^?返ってきます(確か、レスポンスが戻ってくる順番はHTTPの仕様で保証されていたはず、、、(*1)。)
(*1) レスポンスの順番を保証している部分は、 た ぶ ん 、、、 RFC2616の8.1.2.2 パイプライン化かな〜、、、?? と思っているんですけれど、教えて>詳しい方。

8.1.2.2 パイプライン化
永続的な接続をサポートするクライアントはそのリクエストを (それぞれのレスポンスを待つことなしに複数のリクエストを送る) "パイプライン" する事ができる。サーバはリクエストが受信されたのと同じ順番でそれらのリクエストのレスポンスを返さなければならない。 『RFC2616』


【ソース】

サーバー側
test1.php
<?php //2秒寝ます、、、ぐ〜ぐ〜 sleep(2); //じゃ、レスしますね。 echo "testText:" ; ?>

js側
test1_1.htm
<!-- 暫定Ajaxライブラリ --> <script language = "JavaScript" charset = "Shift_JIS" src = "./jslb_ajax.js"></script> <script language="JavaScript"> <!-- //ファイルを読み、responseTextの値を処理の順番に確認します function getTxtFile(fileName,async) { //XMLHttpRequestオブジェクト生成(2005.4.30修正) //res = createHttpRequest() var res = createHttpRequest() //open メソッド res.open("POST", fileName , async ) res.onreadystatechange = function() { if (res.readyState==4) { oj = document.getElementById('output') oj.innerHTML += res.responseText } } //send メソッド res.send('') } //--> </script> <b>【Async(非同期)】</b> <br> <input type = "button" value = "'test1.php,false 同期" onclick = "getTxtFile('./test1.php',false)"> <br><br> <b>【Sync(同期)】</b> <br> <input type = "button" value = "'test1.php,true 非同期" onclick = "getTxtFile('./test1.php',true)"> </form> <b>【サーバーからの返信】</b> <div id="output"></div>


追記
2005.4.30.pm22:59
ちょっとまった、、、Firefox(Win,Mac)でSyncだけ返事がないやん、、、。仕様的にはSyncでonreadystatechange使う必要はないぽく読めるのでそこらあたりか??要調査。と、思って今やってみたけど関係ない、、、バグぽい。。。?と、思ったら、もうひとつMozの微妙な反応を発見、 Asyncの方でも、readyState:3でresponseTextが帰ってきてます(IEの仕様では、「3だとresponseTextプロパティはエラーを返すでしょう」なんですが、解釈の問題ってところです。)ようするに、readyState チェックだけでは駄目ってことですね。、、、うー、やることが増えていく、、、。