第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

章節(jié)
問答
課簽
筆記
評論
占位
占位

Sizzle過濾器原理(上)

怎么有效的從種子合集seed里面找到選擇器指定的元素?這里sizzle引入了過濾器,其原理如下:

function addCombinator(elems) {
   //代碼右圖所示
}

這里只做了2層過濾查找,但是這個(gè)原理其實(shí)就很明了從右到左取出對應(yīng)的條件,然后通過瀏覽器給出的原生的API判斷是否能取到對應(yīng)的指判斷從而篩選其結(jié)果。

過濾處理我們需要考慮的問題:

1 怎么有效的匹配這些選擇器的最小判斷單元,也就是通過詞法分割出后的結(jié)果
2 如果處理層級選擇器的判斷問題

如上可見,過濾是通過一層一層往上回溯不斷的循環(huán)去查找,這樣雖然結(jié)果可以拿到,但是效率是非常低的。所以sizzle從1.8后采用了空間換時(shí)間的方式,通過把各種過濾器編譯成閉包的函數(shù),所以這個(gè)過程也可說是"編譯函數(shù)"。

在Sizzle中過濾器 Expr.filter主要分6大類型

ID”,“TAG”、“CLASS”、“ATTR”、“CHILD”、“PSEUDO”

ID的過濾器

Expr.filter["ID"] = function(id) {
    var attrId = id.replace(runescape, funescape);
    return function(elem) {
        return elem.getAttribute("id") === attrId;
    };
};

TAG類型的過濾器

"TAG": function(nodeNameSelector) {
    var nodeName = nodeNameSelector.replace(runescape, funescape).toLowerCase();
    return nodeNameSelector === "*" ?
        function() {
            return true;
    } :
        function(elem) {
            return elem.nodeName && elem.nodeName.toLowerCase() === nodeName;
    };
},

其實(shí)我們看過濾器的就是一個(gè)具體的判斷方法,通過傳遞一個(gè)上下文元素,來判斷是否存在,得到這一個(gè)布爾值,這樣有效了緩存了重復(fù)的處理,來節(jié)約判斷的過程,下章節(jié)就會提到的“函數(shù)編譯”中具體集合使用。

任務(wù)

?不會了怎么辦
||

提問題

寫筆記

公開筆記
提交
||

請驗(yàn)證,完成請求

由于請求次數(shù)過多,請先驗(yàn)證,完成再次請求

加群二維碼

打開微信掃碼自動綁定

您還未綁定服務(wù)號

綁定后可得到

  • · 粉絲專屬優(yōu)惠福利
  • · 大咖直播交流干貨
  • · 課程更新,問題答復(fù)提醒
  • · 賬號支付安全提醒

收藏課程后,能更快找到我哦~

使用 Ctrl+D 可將課程添加到書簽

邀請您關(guān)注公眾號
關(guān)注后,及時(shí)獲悉本課程動態(tài)

舉報(bào)

0/150
提交
取消
全部 精華 我要發(fā)布
全部 我要發(fā)布
最熱 最新
只看我的

手記推薦

更多

本次提問將花費(fèi)2個(gè)積分

你的積分不足,無法發(fā)表

為什么扣積分?

本次提問將花費(fèi)2個(gè)積分

繼續(xù)發(fā)表請點(diǎn)擊 "確定"

為什么扣積分?