日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

jQuery 源码分析笔记(3)

發布時間:2024/4/17 编程问答 32 豆豆
生活随笔 收集整理的這篇文章主要介紹了 jQuery 源码分析笔记(3) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
###Deferred機制

從1.5版本開始,jQuery加入了Deferred功能,讓事件處理隊列更加的完善。并用 這個機制重寫了Ajax模塊。雖然還沒輪到Ajax,但是接下來的事件處理函數中牽扯到了 這個機制,所以提前看這段代碼。

Deferred把回調函數注冊到一個隊列中,統一管理,并且可以同步或者異步地調用 這些函數。jQuery.Deferred()用來構造一個Deferred對象。該對象有狀態值,共有三種: Rejected, Resolved和初始狀態。其中Resolved表示該操作成功完成了,而Rejected 則表示出現了錯誤,調用失敗。Deferred對象的主要成員如下:

* done(callback): 注冊一個callback函數,當狀態為resolved時被調用。 * fail(callback): 注冊一個callback函數,當狀態為rejected時被調用。 * always(callback): 注冊一個callback函數,無論是resolved或者rejected都會被 調用。 * then(successCallback, failureCallback): 同時傳入成功和失敗的回調函數。 * pipe(successFilter, failureFilter): 在調用成功和失敗的回調函數前先調用pipe 指定的函數。算是一種管道機制,攔截了函數調用。 * resolve(args): 把狀態設置為Resolved。 * reject(args): 把狀態設置為Rejected。 * promse(): 返回的是一個不完整的Deferred的接口,沒有resolve和reject。即不能 修改Deferred對象的狀態。可以看作是一種只讀視圖。這是為了不讓外部函數提早觸發 回調函數。比如$.ajax在1.5版本后不再返回XMLHttpRequest,而是返回一個封裝了 XMLHttpRequest和Deferred對象接口的object。其中Deferred部分就是promise()得到 的,這樣不讓外部函數調用resolve和reject,防止在ajax完成前觸發回調函數。把這 兩個函數的調用權限保留給ajax內部。

這個模塊的代碼從939行開始,緊接著jQuery對象的聲明。也算是一個基礎核心代碼了。 同時也是1.5版本最大的變化之一。

實際上Resolve和Reject的代碼邏輯是一樣的,只是對應的狀態不同而已。為了代碼復用, 內部先實現了一個\_Deferred,然后真正的Deferred內部new了兩個\_Deferred,一個作為 Resolve,另一個作為Reject。

\_Deferred對象內部維護了一個函數數組(callback list)。Done(f1, f2...)的工作 就是把這些callback依次push到這個隊列中保存下來。而resolveWith(帶參的resolve) 和resolve依次調用這寫callback函數。

Done中,需要判斷事件是否已經完成。如果callback加入chain時事件已經完成,則 需要馬上執行callback。這個特性是讓callback不用再和觸發異步事件聲明寫在一起 的原因。比如原來必須寫$.post("...", function(data) { ... })。這個success callback必須寫在這里,而現在可以寫:

var defer = $.post("..."); // ... defer.success(function(data) {// ... }); // ... defer.fail(function(data) {// ... });

這樣異步事件的聲明和回調函數就可以分別管理了。這是1.5版本重寫后的最大變化。

pipe(successFilter, failureFilter)函數修改了原來對象中的callback list。在兩個callback list前面用then函數分別插入了Filter函數。然后返回。這樣當這個Deferred對象的狀態變化時,會 先調用pipe函數指定的Filter函數,然后才會調用callback list。

promise()則單純許多,就是new一個新object,然后把需要的成員copy進去。這個需要的成員定義在 一個叫promiseMethods常量中。

var promiseMethods = "done fail isResolved isRejected promise then always pipe".split(" ");

PS: 今天把Markdown環境配置好后,用vim編寫Markdown,然后復制過來直接發布。感覺不錯

轉載于:https://www.cnblogs.com/fjzhou/archive/2011/05/30/jquery-source-3.html

總結

以上是生活随笔為你收集整理的jQuery 源码分析笔记(3)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日韩精品视频久久 | 国产对白刺激视频 | 日韩免费高清一区二区 | 日噜噜夜噜噜 | 国产污污视频 | 久久久国产精品一区 | 国产www网站 | 91免费精品| 国产成人免费在线观看 | 精品一区二区三区日韩 | 狠狠av | 黄网在线观看视频 | 五月婷婷婷| 国产福利合集 | 户外少妇对白啪啪野战 | 激情内射亚洲一区二区三区爱妻 | 麻豆视频在线观看免费 | 国产三区四区视频 | 黄网站在线观看 | 久久久久久久免费 | 激情深爱五月 | 黄色成人影视 | 国产情侣露脸自拍 | 亚洲综合第一页 | 992tv在线成人免费观看 | av中文天堂 | 超碰免费91 | 色涩综合| 综合网av | 天天插天天狠天天透 | 日韩在线一卡 | 91亚洲精品国偷拍自产在线观看 | www操操操 | 精品无码一区二区三区 | 国产精品亚洲第一 | 欧美人妖老妇 | 少妇学院在线观看 | 色精品视频 | 青青操青青 | 黄色免费网站在线看 | 亚洲视频999 | 欧美黑人性受xxxx精品 | 人人天天夜夜 | 亚洲欧美激情精品一区二区 | 看全色黄大色黄大片大学生 | 黄色av网站在线 | 91精品免费在线观看 | 狠狠操网站 | 日本免费黄色网址 | 欧美一级淫片免费视频黄 | 男性影院| 性xxxx另类xxⅹ | 免费一级黄色片 | 亚洲色图小说 | 国产福利一区在线观看 | 色四月 | 欧美日韩中文视频 | 国产欧美日韩视频在线观看 | 最新中文字幕在线观看视频 | 国产美女精品人人做人人爽 | 日韩三级中文字幕 | 欧美日韩精品网站 | 91播放在线 | 亚洲中文字幕在线一区 | 羞羞动漫在线观看 | 9i看片成人免费 | 亚洲第一黄色片 | 亚洲播播 | 一区二区成人精品 | 国产一区在线观看视频 | 亚洲国产精品毛片av不卡在线 | 日韩成人精品在线观看 | 成人av不卡 | 欧美一区二区三区四区五区六区 | 天天射天天搞 | 私库av在线 | 国产一级片av | 亚洲天堂中文 | 国产又黄又粗又长 | 毛片天堂 | 国产成人av一区 | 3d动漫精品啪啪一区二区竹菊 | 老熟妇一区二区三区啪啪 | 五月天丁香 | 无码人妻精品一区二区三区夜夜嗨 | 人妻熟女一区 | 91女人18毛片水多国产 | 久久久久久av无码免费看大片 | 久久女同互慰一区二区三区 | 国产+日韩+欧美 | 免费国产小视频 | 国产私拍 | 伊人伊人网 | 久久亚洲AV无码专区成人国产 | 国产91沙发系列 | 一区二区在线免费看 | 污污网址在线观看 | 特一级黄色片 | 狼人伊人干|