通過Expr.find[ type ]我們找出選擇器最右邊的最終seed種子合集,通過Sizzle.compile函數(shù)編譯器,我們把tokenize詞法元素編譯成閉包函數(shù)。
超級匹配superMatcher,用最佳的方式從seed種子集合篩選出需要的數(shù)據(jù),也就是通過seed與compile的匹配,得出最終的結果。
superMatcher 函數(shù)
這個方法并不是一個直接定義的方法,通過matcherFromGroupMatchers( elementMatchers, setMatchers )方法return出來的一個curry化的函數(shù),但是最后執(zhí)行起重要作用的是它。
注意是compile()():
compile( selector, match )( seed, context, !documentIsHTML, results, rsibling.test( selector ) && testContext( context.parentNode ) || context );
superMatcher方法會根據(jù)參數(shù)seed 、expandContext和context確定一個起始的查詢范圍:
elems = seed || byElement && Expr.find["TAG"]( "*", outermost ),
有可能是直接從seed中查詢過濾,也有可能在context或者context的父節(jié)點范圍內。如果不是從seed開始,那只能把整個DOM樹節(jié)點取出來過濾了,把整個DOM樹節(jié)點取出來過濾了,它會先執(zhí)行Expr.find["TAG"]( "*", outermost )這句代碼等到一個elems集合(數(shù)組合集)。
context.getElementsByTagName( tag );
可以看出對于優(yōu)化選擇器,最右邊應該寫一個作用域的搜索范圍context比較好。
開始遍歷這個seed種子合集了:
while ( (matcher = elementMatchers[j++]) ) { if ( matcher( elem, context, xml ) ) { results.push( elem ); break; } }
elementMatchers:就是通過分解詞法器生成的閉包函數(shù)了,也就是“終極匹配器”。
為什么是while?
前面就提到了,tokenize選擇器是可以用過 “,”逗號分組 group,所以就會有個合集的概念了,matcher就得到了每一個終極匹配器。
通過代碼很能看出來matcher方法運行的結果都是bool值,對里面的元素逐個使用預先生成的matcher方法做匹配,如果結果為true的則直接將元素堆入返回結果集。
請驗證,完成請求
由于請求次數(shù)過多,請先驗證,完成再次請求
打開微信掃碼自動綁定
綁定后可得到
使用 Ctrl+D 可將課程添加到書簽
舉報