亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

jQuery1.9.1源碼分析系列(十六)ajax之ajax框架

2024-09-01 08:33:06
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了jQuery1.9.1源碼分析系列(十六)ajax之ajax框架 的相關資料,需要的朋友可以參考下
 

AJAX 簡介

AJAX 是一種在無需重新加載整個網頁的情況下,能夠更新部分網頁的技術。

您應當具備的基礎知識

在繼續學習之前,您需要對下面的知識有基本的了解:

HTML / XHTML
CSS
JavaScript / DOM

如果您希望首先學習這些項目,請在我們的首頁訪問這些教程。

什么是 AJAX ?

AJAX = 異步 JavaScript 和 XML。

AJAX 是一種用于創建快速動態網頁的技術。

通過在后臺與服務器進行少量數據交換,AJAX 可以使網頁實現異步更新。這意味著可以在不重新加載整個網頁的情況下,對網頁的某部分進行更新。

傳統的網頁(不使用 AJAX)如果需要更新內容,必需重載整個網頁面。

有很多使用 AJAX 的應用程序案例:新浪微博、Google 地圖、開心網等等。

Google Suggest

在 2005 年,Google 通過其 Google Suggest 使 AJAX 變得流行起來。

Google Suggest 使用 AJAX 創造出動態性極強的 web 界面:當您在谷歌的搜索框輸入關鍵字時,JavaScript 會把這些字符發送到服務器,然后服務器會返回一個搜索建議的列表。

今天就開始使用 AJAX

AJAX 基于已有的標準。這些標準已被大多數開發者使用多年。

既然是ajax框架,那么閑談一談jQuery的ajax處理思路。

  現在的瀏覽器都支持ajax,只不過不同的瀏覽器使用方法可能有不同(IE使用new window.ActiveXObject("Microsoft.XMLHTTP"),標準瀏覽器使用new window.XMLHttpRequest())。如果按照這種思路,貌似jQajax只需要做好兼容處理就行了?

  不是的,原生的ajax有一個說大不大說小不小的缺點——不支持跨域(同源策略由來已久,自行百度)。所以jQajax添加了這方面的處理,jQajax是如何解決跨域問題的?

  <img src="http://img2.imgtn.bdimg.com/it/u=2406301718,2822592556&fm=21&gp=0.jpg"/>

  是能取到圖片的,很明顯圖片的路徑和你的服務端不是一個域的。你可以試試看所有的帶有src屬性的標簽都不受同源策略的影響。所以,jQuery就使用了這個屬性,對于跨域請求使用script標簽的src來請求路徑。

  然后jQuery在加上對ajax事件的三種監聽方式:

  1.全局事件:$(document).on(‘ajaxStart',func);

  2.ajax設置回調項:$.ajax({url: "php.html", complete: func });

  3.deferred綁定方式:$.ajax(…).done(func);

  基本上這就是jQajax所做的事情。

  在正真進入ajax框架核心之前,先來分析一jQuery準備的幾個序列化提交表單的函數。

a. 表單序列化

  所謂的表單序列化即將表單需要提交的內容組成類似:“key=value&key=value…”形式的字符串。

  序列化用到三個函數:

  jQuery.fn. serialize()(序列化函數,篩選出表單中需要提交的數據并以序列化字符串方式返回,形如:“key=value&key=value…”)

  jQuery.fn. serializeArray()(篩選出表單中需要提交的數據并以key/value鍵值對的對象數組格式返回,返回[{name:'key',value:'select1'},{name:'selectM',value:'selectM1'}, {name:'selectM',value:'selectM2'}, { name:'key2',value:0}…])

  jQuery.param(serializeArray, traditional )(將key/value鍵值對的對象數組序列化為“key=value&key=value…”字符串)。

  serialize直接調用jQuery.param( this.serializeArray() )即可。

  serializeArray的源碼如下:主要進行三個步驟:提取表單元素、過濾出滿足提交條件的表單元素、組合成key/value鍵值對的對象數組

serializeArray: function() {  //將form中的表單相關的元素取出來組成數組  return this.map(function(){    //表單節點有elements這個特征    var elements = jQuery.prop( this, "elements" );    return elements ? jQuery.makeArray( elements ) : this;  })  //過濾出為需要提交的表單元素(有name名稱、非disabled元素、非提交按鈕等元素、checkbox/radio的checked的元素)  .filter(function(){    var type = this.type;    //使用.is(":disabled")過濾掉不可用的表單元素    return this.name && !jQuery( this ).is( ":disabled" ) &&    rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) &&    ( this.checked || !manipulation_rcheckableType.test( type ) );  })  //將表單提交元素組成name和value的對象數組  .map(function( i, elem ){    var val = jQuery( this ).val();    return val == null ?    null :    jQuery.isArray( val ) ?    jQuery.map( val, function( val ){      return { name: elem.name, value: val.replace( rCRLF, "/r/n" ) };    }) :    { name: elem.name, value: val.replace( rCRLF, "/r/n" ) };  }).get();} 

  需要注意的是jQuery的過濾結果符合正常的表單提交結果://過濾出為需要提交的表單元素(有name名稱、非disabled元素、非提交按鈕等元素、checkbox/radio的checked的元素)

  param函數源碼如下:主要進行兩個處理:將key/value成作為URI組件編碼(保證key和value不會出現特殊符號,即保證了“=”分割的正確性)、使用“&”鏈接并將空白符被替換成了"+"

jQuery.param = function( a, traditional ) {  var prefix,  s = [],  add = function( key, value ) {      //如果value是函數,執行他得到真正的value      value = jQuery.isFunction( value ) ? value() : ( value == null ? "" : value );      //把key和value作為URI組件編碼,保證key和value不會出現特殊符號,即保證了“=”分割的正確性      s[ s.length ] = encodeURIComponent( key ) + "=" + encodeURIComponent( value );    };  ...  //傳入的是數組,假設他是一個form表單鍵值對數組  if ( jQuery.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) {    //序列化表單元素    jQuery.each( a, function() {      add( this.name, this.value );    });  } else {    ...  }  //返回序列化結果,注意:空白符被替換成了"+"  return s.join( "&" ).replace( r20, "+" );}; 

  其中encodeURIComponent詳細點擊查看

b. ajax的事件監聽

  給ajax綁定事件有三種方式

  1.全局事件:$(document).on(‘ajaxStart',func);

  2.ajax設置回調項:$.ajax({url: "php.html", complete: func }); 

  3.deferred綁定方式:$.ajax(…).done(func);

  接下來我們一一講解他們的實現。

全局事件(ajaxStart/ajaxStop/ajaxComplete/ajaxError/ajaxSuccess/ajaxSend)

  使用.on事件綁定這種通用方式我們毫無疑問是可以綁定ajax監聽事件,除此之外還可以直接使用$(…).ajaxStart(func)來綁定事件。他們的實現也是用.on來綁定。

jQuery.each( [ "ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend" ], function( i, type ){    jQuery.fn[ type ] = function( fn ){      return this.on( type, fn );    };}); 

  觸發事件比較簡單,在進行ajax處理過程中在合適的時機直接使用jQuery.event.trigger直接觸發。以ajaxStart為例

   //如果此時沒有正在執行的請求,則觸發ajaxStart事件      if ( fireGlobals && jQuery.active++ === 0 ) {        jQuery.event.trigger("ajaxStart");      }  

ajax設置回調項(beforeSend/complete/success/error)

  觸發設置回調項分兩種:beforeSend直接在適當的時機調用。源碼

//調用beforeSend回調,如果回調返回失敗或abort則返回中止if ( s.beforeSend && ( s.beforeSend.call( callbackContext, jqXHR, s ) === false || state === 2 ) ) {        //中止如果沒有準備好        return jqXHR.abort();      }   complete/success/error則利用Deferred的特性將回調添加到延時隊列,等待延時狀態處理。源碼//創建最終選項對象s = jQuery.ajaxSetup( {}, options )...deferred = jQuery.Deferred(),completeDeferred = jQuery.Callbacks("once memory"),...//添加延時事件deferred.promise( jqXHR ).complete = completeDeferred.add;jqXHR.success = jqXHR.done;jqXHR.error = jqXHR.fail;//安裝回調到deferreds上for ( i in { success: 1, error: 1, complete: 1 } ) {jqXHR[ i ]( s[ i ] );}//在ajax請求完成的處理函數中執行completeDeferred的延時列表function done(){...//執行Complete處理completeDeferred.fireWith( callbackContext, [ jqXHR, statusText ] );...} 

deferred方式綁定回調

  Deferred方式綁定事件就不用特別說明了,因為ajax本身就是一個延時對象。直接使用$.ajax(…).done(fn).fail(fn). progress(fn).always(fn).then(fn)。源碼

deferred = jQuery.Deferred(),completeDeferred = jQuery.Callbacks("once memory"),...deferred.promise( jqXHR ).complete = completeDeferred.add;...return jqXHR;


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩亚洲综合在线| 色青青草原桃花久久综合| 欧美激情国产精品| 91亚洲午夜在线| 欧美在线观看网站| 国产在线视频一区| 久久不射电影网| 国产精品av网站| 欧洲成人免费aa| 久99九色视频在线观看| 亚洲欧美中文字幕在线一区| 成人网在线免费观看| xx视频.9999.com| 亚洲欧美另类自拍| 欧洲亚洲女同hd| 粉嫩老牛aⅴ一区二区三区| 最近2019中文字幕第三页视频| 欧美天天综合色影久久精品| 欧美一区二区三区四区在线| 少妇精69xxtheporn| 91中文字幕在线观看| 国产视频欧美视频| 久久久久久久久久久网站| 欧美日韩成人在线视频| 亚洲第一免费网站| 亚洲va久久久噜噜噜久久天堂| 亚洲精品一区二区三区婷婷月| 亚洲xxxx妇黄裸体| 欧美激情按摩在线| 欧美成人免费全部| 国产精品久久久久免费a∨大胸| 欧美精品激情在线| 高清日韩电视剧大全免费播放在线观看| 日韩中文字幕网| 在线丨暗呦小u女国产精品| 国产盗摄xxxx视频xxx69| 亚洲的天堂在线中文字幕| 精品毛片网大全| 亚洲性视频网址| 中文字幕成人精品久久不卡| 亚洲人成五月天| 国产精品中文字幕久久久| 国产精品亚洲欧美导航| 亚洲国产成人精品久久久国产成人一区| 亚洲欧美日韩另类| 日韩免费观看网站| 热re91久久精品国99热蜜臀| 亚洲午夜女主播在线直播| 色阁综合伊人av| 国内精品在线一区| 在线丨暗呦小u女国产精品| 日本人成精品视频在线| 亚洲国产精品va在线观看黑人| 国产精品一区二区久久国产| 久久精品一区中文字幕| 国产日韩精品电影| 日韩中文字幕在线观看| 日日骚av一区| 日韩有码片在线观看| 欧美自拍视频在线观看| 欧美日韩在线观看视频| 久久人人爽人人| 日本精品一区二区三区在线播放视频| 国内精品久久久久久| 69久久夜色精品国产69乱青草| 亚洲精品不卡在线| 亚洲一区制服诱惑| 亚洲石原莉奈一区二区在线观看| 国产精品久久久久久久7电影| 亚洲欧美日韩精品久久| 91中文精品字幕在线视频| 亚洲福利视频网| 亚洲综合av影视| 亚洲无线码在线一区观看| xxxx性欧美| 视频一区视频二区国产精品| 精品夜色国产国偷在线| 亚洲欧洲高清在线| 亚洲欧美激情另类校园| 岛国av在线不卡| 欧美另类交人妖| 国产精品国内视频| 久久中文字幕在线视频| 日韩欧美亚洲综合| 欧美日韩在线观看视频小说| 欧美性生活大片免费观看网址| 一本色道久久综合狠狠躁篇的优点| 国产成+人+综合+亚洲欧美丁香花| 久久久久久久久久久免费| 亚洲精品日韩av| 亚洲精品永久免费| 欧美黑人视频一区| 成人精品aaaa网站| 国产精品高清网站| 国产精品777| 日韩av理论片| 日韩人在线观看| 久久综合国产精品台湾中文娱乐网| 国产丝袜一区二区三区免费视频| 日韩av最新在线观看| 国产精品久久久久一区二区| 这里只有精品在线播放| 亚洲福利精品在线| 亚洲欧洲国产一区| 尤物九九久久国产精品的特点| 久久精品2019中文字幕| 亚洲一区二区三区xxx视频| 亚洲一区国产精品| 91成品人片a无限观看| 久青草国产97香蕉在线视频| 欧美黑人一区二区三区| 最新日韩中文字幕| 欧美极品少妇与黑人| 亚洲在线免费视频| 久久人体大胆视频| 久久噜噜噜精品国产亚洲综合| 国产精品第七影院| 欧美精品aaa| 国产精品视频xxxx| 亚洲精品小视频| 欧美日韩国产综合视频在线观看中文| 国产精品99久久久久久www| 岛国av午夜精品| 成人久久久久久久| 91香蕉电影院| 18久久久久久| 在线成人激情视频| 亚洲毛片在线看| 日韩欧美精品免费在线| 欧美精品在线观看| 亚洲女人天堂成人av在线| 亚洲欧美国产精品va在线观看| 高清欧美性猛交| 成人性教育视频在线观看| www.国产一区| 久久这里有精品| 亚洲国产欧美久久| 国产精品1区2区在线观看| 欧美电影电视剧在线观看| 欧美激情视频在线免费观看 欧美视频免费一| 亚洲国产小视频在线观看| 国产98色在线| 精品国内产的精品视频在线观看| 国内外成人免费激情在线视频| 国产精品羞羞答答| 亚洲最新av网址| 成人久久久久久| 欧美xxxx做受欧美| 欧美大胆a视频| 亚洲激情中文字幕| 亚洲第一中文字幕在线观看| 日韩在线观看高清| 久久久极品av| 午夜精品一区二区三区在线视频| 亚洲男人第一网站| 日韩中文字幕国产| 日本久久久久久久久| 亚洲欧美激情另类校园| 亚洲美女喷白浆| 最新国产成人av网站网址麻豆| 91免费欧美精品| 日韩av手机在线| 伊人久久大香线蕉av一区二区| 亚洲欧洲偷拍精品|