<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    I'll be back!

      Focus on BPM, celebrate PegaRULES Process Commander (PRPC)
    posts - 76, comments - 161, trackbacks - 0, articles - 2
      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

    dojo.io.bind 介紹

    Posted on 2006-10-25 11:02 zolly 閱讀(2030) 評論(1)  編輯  收藏
    Introduction to dojo.io.bind
    ? ?dojo.io包很好的封裝了XMLHTTP和其它比較復雜的傳輸機制(iframe等)。另外"transports"傳輸器以插件形式(實現的統一的接口)出現,另外dojo對于XMLHTTP的支持解決了back button的問題。我們先拋開細節,看看dojo提供給我們的public API.
    ? ?dojo.io的許多不可思議的功能都由bind()方法來實現。(可能腳本語言或不定參數的語言都喜歡這樣,說實話,我不喜歡)。dojo.io.bind()是一個普通的匿名請求API,它的底層可以是不同的傳輸機制(queues of iframes, XMLHTTP, mod_pubsub, LivePage, 等)。dojo會嘗試選擇最好的傳輸機制,如果你的環境支持多種傳輸機制,XMLHTTP會是dojo的首選。bind()方法的參數是一個簡單的匿名對象,當然這個對象的屬性是異常靈活的。
    ?如果你要得到一個text文件,可能代碼如下:

    dojo.io.bind({
    ???url:?
    "http://foo.bar.com/sampleD,
    ???load:?function(type,?data,?evt){?/*do?something?w/?the?data?*/?},
    ???mimetype:?
    "text/plain"
    });

    和prototype.js/YUI等差不多,簡單的代碼可以得到數據。可能你也想到,如果出現錯誤怎么 辦,簡單注冊一個錯誤處理函數就好了:

    dojo.io.bind({
    ???url:?
    "http://foo.bar.com/sampleD,
    ???load:?function(type,?data,?evt){?/*do?something?w/?the?data?*/?},
    ???error:?function(type,?error){?/*do?something?w/?the?error*/?},
    ???mimetype:?
    "text/plain"
    });


    dojo也可以把所有的處理放到一個函數里,如下:

    dojo.io.bind({
    ???url:?
    "http://foo.bar.com/sampleD,
    ???handle:?function(type,?data,?evt){
    ???????if(type?==?
    "load"){
    ???????????//?do?something?with?the?data?object
    ???????}else?if(type?==?
    "error"){
    ???????????//?here,?
    "data"?is?our?error?object
    ???????????//?respond?to?the?error?here
    ???????}else{
    ???????????//?other?types?of?events?might?get?passed,?handle?them?here
    ???????}
    ???},
    ???mimetype:?
    "text/plain"
    });

    考慮性能原因,Ajax經常重服務器返回一段可執行的javascript代碼段,在瀏覽器中eval(它)。你只要指定mimetype: "text/javascript" 就

    可以了,dojo會自動為你 eval這些javascript代碼,

    dojo.io.bind({
    ???url:?
    "http://foo.bar.com/sampleD,
    ???load:?function(type,?evaldObj){?/*?do?something?*/?},
    ???mimetype:?
    "text/javascript"
    });

    你也可以指定你使用哪種傳輸器 如 XMLHTTPTransport:

    dojo.io.bind({
    ???url:?
    "http://foo.bar.com/sampleD,
    ???load:?function(type,?evaldObj){?/*?do?something?*/?},
    ???mimetype:?
    "text/plain",?//?get?plain?text,?don't?eval()
    ???transport:?
    "XMLHTTPTransport"
    });


    Being a jack-of-all-trades, bind() also supports the submission of forms via a request (with the single caveat that it won't do file upload over XMLHTTP):
    ????得看看代碼?是否url會覆蓋action.

    dojo.io.bind({
    ???url:?
    "http://foo.bar.com/process,
    ???load:?function(type,?evaldObj){?/*?do?something?*/?},
    ???formNode:?document.getElementById(
    "formToSubmit")
    });


    呵呵,不錯吧。下面看看幾個傳輸器。

    Transports:
    dojo.io.bind和其它相關函數與服務器通信有幾種方法,叫Transport,每種Transports可能都有缺陷,因此在特定場合你必須選擇合適的transport。
    默認的transport是大家熟悉的 XMLHttp.

    XMLHttp

    xmlhttp在大部分情況下工作的很好,但它不能上傳文件,不能跨域工作,也不能在file://協議下工作。(dojo也代替的方案)

    例子代碼:

    <script?type="text/javascript">???dojo.require("dojo.io.*");???
    function?mySubmit({?????
    ???dojo.io.bind?(
    {???????
    ???url:?'server.cfm',??????
    ???handler:?callBack,???????????
    ???formNode:?dojo.byId('myForm')????
    ?}
    );??
    }
    ???
    function?callBack(type,?data,?evt)?{??
    ???dojo.byId('result').innerHTML?
    =?data;??
    }

    </script>


    IFrame I/O:
    IFrame I/O transport是有用的,它可以上傳文件. ?例子代碼:

    <script?type="text/javascript">???dojo.require("dojo.io.*");???
    dojo.require(
    "dojo.io.IframeIO");?
    function?mySubmit()?{?????
    ?dojo.io.bind?(
    {???????????url:?'server.cfm',???????
    ???handler:?callBack,???????
    ???formNode:?dojo.byId('myForm')???????}
    );???
    }
    ???
    function?callBack(type,?data,?evt)?{??????
    ?dojo.byId('result').innerHTML?
    =?data;???
    }

    </script>

    The response type from the above URL can be text, html, or JS/JSON.
    這種響應類型的url可以是text,html或者js/json.

    摘自:zkjbeyondhttp://zkj.wisekernel.net/read.php/14.htm

    評論

    # re: dojo.io.bind 介紹  回復  更多評論   

    2013-08-12 02:16 by whut_lp
    受益匪淺

    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 亚洲va在线va天堂va888www| 亚洲国产精品丝袜在线观看| 久久久久亚洲AV成人片| 中文字幕一区二区免费| 一本色道久久综合亚洲精品| 亚洲一区二区三区免费| 亚洲无人区一区二区三区| 一级毛片免费在线观看网站| 亚洲女同成人AⅤ人片在线观看| 一级毛片a女人刺激视频免费| 亚洲国产精品成人| av片在线观看永久免费| 亚洲男人的天堂www| 十九岁在线观看免费完整版电影| 亚洲一区二区三区电影| 久久久久久精品免费看SSS| 色噜噜亚洲男人的天堂| 永久免费bbbbbb视频| 青青青亚洲精品国产| 伊人久久亚洲综合| 久久精品免费观看国产| 亚洲国产成AV人天堂无码| 大陆一级毛片免费视频观看| 精品一区二区三区免费毛片| 亚洲乳大丰满中文字幕| 精品免费久久久久久久| 免费亚洲视频在线观看| 久久久久久a亚洲欧洲aⅴ| 成人免费一级毛片在线播放视频| 亚洲a∨无码一区二区| 最新精品亚洲成a人在线观看| 最近中文字幕无免费| 亚洲大码熟女在线观看| 亚洲人成色777777在线观看| 欧洲一级毛片免费| 深夜a级毛片免费视频| 亚洲一区中文字幕久久| 国产视频精品免费| 99久久国产免费中文无字幕| 亚洲色最新高清av网站| 国产偷v国产偷v亚洲高清|