摘要:調(diào)用來獲取符合條件的集合元素,這在上篇文章讀源碼之神奇的已經(jīng)有詳細的論述。然后調(diào)用方法來合并兩個集合,用內(nèi)部方法來過濾掉重復的項,方法在讀源碼之內(nèi)部方法已經(jīng)有論述。最后也是返回一個集合。
接下來幾個篇章,都會解讀 zepto 中的跟 dom 相關(guān)的方法,也即源碼 $.fn 對象中的方法。
讀Zepto源碼系列文章已經(jīng)放到了github上,歡迎star: reading-zepto
源碼版本本文閱讀的源碼為 zepto1.2.0
.forEach()forEach: emptyArray.forEach
因為 zepto 的 dom 集合是類數(shù)組,所以這里只是簡單地復制了數(shù)組的 forEach 方法。
具體的 forEach 的用法見文檔:Array.prototype.forEach()
.reduce()reduce: emptyArray.reduce
簡單地復制了數(shù)組的 reduce 方法。
具體的 reduce 的用法見文檔:Array.prototype.reduce()
.push()push: emptyArray.push
簡單地復制了數(shù)組的 push 方法。
具體的 push 的用法見文檔:Array.prototype.push()
.sort()sort: emptyArray.sort
簡單地復制了數(shù)組的 sort 方法。
具體的 sort 的用法見文檔:Array.prototype.sort()
.splice()splice: emptyArray.splice
簡單地復制了數(shù)組的 splice 方法。
具體的 splice 的用法見文檔:Array.prototype.splice()
.indexOf()indexOf: emptyArray.indexOf
簡單地復制了數(shù)組的 indexOf 方法。
具體的 indexOf 的用法見文檔:Array.prototype.indexOf()
.get()get: function(idx) { return idx === undefined ? slice.call(this) : this[idx >= 0 ? idx : idx + this.length] },
這個方法用來獲取指定索引值的元素。
不傳參(idx === undefined)時,不傳參調(diào)用數(shù)組的 slice 方法,將集合中的所有元素返回。
當傳遞的參數(shù)大于或等于零(idx)時,返回相應(yīng)索引值的元素 this[idx] ,如果為負數(shù),則倒數(shù)返回this.[idx + this.length]。
例如 $("li").get(-1) 返回的是倒數(shù)第1個元素,也即最后一個元素
.toArray()toArray: function() { return this.get() }
toArray 方法是將元素的類數(shù)組變成純數(shù)組。toArray 內(nèi)部不傳參調(diào)用 get 方法,上面已經(jīng)分析了,當不傳參數(shù)時,get 方法調(diào)用的是數(shù)組方法 slice, 返回的自然就是純數(shù)組了。
.size()size: function() { return this.length }
size 方法返回的是集合中的 length 屬性,也即集合中元素的個數(shù)。
.concat()concat: function() { var i, value, args = [] for (i = 0; i < arguments.length; i++) { value = arguments[i] args[i] = zepto.isZ(value) ? value.toArray() : value } return concat.apply(zepto.isZ(this) ? this.toArray() : this, args) },
數(shù)組中也有對應(yīng)的 concat 方法,為什么不能像上面的方法那樣直接調(diào)用呢?
這是因為 $.fn 其實是一個類數(shù)組對象,并不是真正的數(shù)組,如果直接調(diào)用 concat 會直接把整個 $.fn 當成數(shù)組的一個 item 合并到數(shù)組中。
for (i = 0; i < arguments.length; i++) { value = arguments[i] args[i] = zepto.isZ(value) ? value.toArray() : value }
這段是對每個參數(shù)進行判斷,如果參數(shù)是 zepto 的集合(zepto.isZ(value)),就先調(diào)用 toArray 方法,轉(zhuǎn)換成純數(shù)組。
return concat.apply(zepto.isZ(this) ? this.toArray() : this, args)
這段同樣對 this 進行了判斷,如果為 zepto 集合,也先轉(zhuǎn)換成數(shù)組。所以調(diào)用 concat 后返回的是純數(shù)組,不再是 zepto 集合。
.map()map: function(fn) { return $($.map(this, function(el, i) { return fn.call(el, i, el) })) }
map 方法的內(nèi)部調(diào)用的是 zepto 的工具函數(shù) $.map ,這在之前已經(jīng)在《讀Zepto源碼之工具函數(shù)》做過了分析。
return fn.call(el, i, el)
map 方法對回調(diào)也做了包裝,call 的第一個參數(shù)為 el ,因此可以在 map 的回調(diào)中通過 this 來拿到每個元素。
map 方法對 $.map 返回的數(shù)組調(diào)用了 $() 方法,將返回的數(shù)組再次包裝成 zepto 對象,因此調(diào)用 map 方法后得到的數(shù)組,同樣具有 zepto 集合中的方法。
.slice()slice: function() { return $(slice.apply(this, arguments)) }
slice 同樣沒有直接用數(shù)組的原生方法,也像 map 方法一樣,將返回的數(shù)組再次包裝成 zepto 對象。
.each()each: function(callback) { emptyArray.every.call(this, function(el, idx) { return callback.call(el, idx, el) !== false }) return this },
zepto 的 each 方法比較巧妙,在方法內(nèi)部,調(diào)用的其實是數(shù)組的 every 方法,every 遇到 false 時就會中止遍歷,zepto 也正是利用 every 這種特性,讓 each 方法也具有了中止遍歷的能力,當 callback 返回的值為布爾值 false 時,中止遍歷,注意這里用了 !==,因為 callback 如果沒有返回值時,得到的值會是 undefined ,這種情況是需要排除的。
同樣,each 的回調(diào)中也是可以用 this 拿到每個元素的。
注意,each 方法最后返回的是 this, 所以在 each 調(diào)用完后,還可以繼續(xù)調(diào)用 集合中的其他方法,這就是 zepto 的鏈式調(diào)用,這個跟 map 方法中返回 zepto 集合的原理差不多,只不過 each 返回的是跟原來一樣的集合,map 方法返回的是映射后的集合。
.add()add: function(selector, context) { return $(uniq(this.concat($(selector, context)))) }
add 可以傳遞兩個參數(shù),selector 和 context ,即選擇器和上下文。
add 調(diào)用 $(selector, context) 來獲取符合條件的集合元素,這在上篇文章《讀Zepto源碼之神奇的$》已經(jīng)有詳細的論述。
然后調(diào)用 concat 方法來合并兩個集合,用內(nèi)部方法 uniq 來過濾掉重復的項,uniq 方法在《讀Zepto源碼之內(nèi)部方法》已經(jīng)有論述。最后也是返回一個 zepto 集合。
系列文章讀Zepto源碼之代碼結(jié)構(gòu)
讀 Zepto 源碼之內(nèi)部方法
讀Zepto源碼之工具函數(shù)
讀Zepto源碼之神奇的$
參考Array.prototype.forEach()
Array.prototype.reduce()
Array.prototype.push()
Array.prototype.sort()
Array.prototype.splice()
Array.prototype.indexOf()
License最后,所有文章都會同步發(fā)送到微信公眾號上,歡迎關(guān)注,歡迎提意見:
作者:對角另一面
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/83117.html
摘要:讀源碼系列文章已經(jīng)放到了上,歡迎源碼版本本文閱讀的源碼為改寫原有的方法模塊改寫了以上這些方法,這些方法在調(diào)用的時候,會為返回的結(jié)果添加的屬性,用來保存原來的集合。方法的分析可以看讀源碼之模塊。 Stack 模塊為 Zepto 添加了 addSelf 和 end 方法。 讀 Zepto 源碼系列文章已經(jīng)放到了github上,歡迎star: reading-zepto 源碼版本 本文閱讀的...
摘要:方法是將集合中不符合條件的元素查找出來。判斷集合中的第一個元素是否匹配指定的選擇器。這個在讀源碼之集合操作有講過,如果集合個數(shù)大于零,則表示滿足條件。返回集合中所有元素指定的屬性值。獲取集合中每個元素的前一個兄弟節(jié)點。 這篇依然是跟 dom 相關(guān)的方法,側(cè)重點是跟集合元素查找相關(guān)的方法。 讀Zepto源碼系列文章已經(jīng)放到了github上,歡迎star: reading-zepto 源碼...
摘要:模塊處理的是表單提交。表單提交包含兩部分,一部分是格式化表單數(shù)據(jù),另一部分是觸發(fā)事件,提交表單。最終返回的結(jié)果是一個數(shù)組,每個數(shù)組項為包含和屬性的對象。否則手動綁定事件,如果沒有阻止瀏覽器的默認事件,則在第一個表單上觸發(fā),提交表單。 Form 模塊處理的是表單提交。表單提交包含兩部分,一部分是格式化表單數(shù)據(jù),另一部分是觸發(fā) submit 事件,提交表單。 讀 Zepto 源碼系列文章已...
摘要:如果偽類的參數(shù)不可以用轉(zhuǎn)換,則參數(shù)為字符串,用正則將字符串前后的或去掉,再賦值給最后執(zhí)行回調(diào),將解釋出來的參數(shù)傳入回調(diào)函數(shù)中,將執(zhí)行結(jié)果返回。重寫的方法,改過的調(diào)用的是方法,在回調(diào)函數(shù)中處理大部分邏輯。 Selector 模塊是對 Zepto 選擇器的擴展,使得 Zepto 選擇器也可以支持部分 CSS3 選擇器和 eq 等 Zepto 定義的選擇器。 在閱讀本篇文章之前,最好先閱讀《...
摘要:輔助方法這個方法遞歸遍歷的子節(jié)點,將節(jié)點交由回調(diào)函數(shù)處理。對集合進行遍歷,調(diào)用方法,如果為函數(shù),則將回調(diào)函數(shù)返回的結(jié)果作為參數(shù)傳給否則,如果為,則將也即包裹元素的副本傳給,否則直接將傳給。 這篇依然是跟 dom 相關(guān)的方法,側(cè)重點是操作 dom 的方法。 讀Zepto源碼系列文章已經(jīng)放到了github上,歡迎star: reading-zepto 源碼版本 本文閱讀的源碼為 zepto...
閱讀 973·2021-11-25 09:43
閱讀 2298·2019-08-30 15:55
閱讀 3160·2019-08-30 15:44
閱讀 2059·2019-08-29 16:20
閱讀 1459·2019-08-29 12:12
閱讀 1614·2019-08-26 12:19
閱讀 2289·2019-08-26 11:49
閱讀 1718·2019-08-26 11:42