亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

css3 - jQuery/CSS選擇器效率問題

瀏覽:112日期:2023-08-05 16:19:33

問題描述

<p id='all'> <p class='class1'>one</p> <p class='class1'>two</p> <p class='class1'>three</p> <p class='class1'>four</p> <p class='class2'>five</p></p>

通過實驗發現$('#all').find('.class2')要比$('#all .class2')性能好,為什么呢?jQuery和CSS都用的是Sizzle選擇器引擎,他的解析方式是從右向左。也有說如果最左邊指定了id,就會先取id,這時是不是就會從左向右匹配了?

問題解答

回答1:

沒看過具體實現,不過,前者顯然是從左到右匹配,後者如果也是,性能應該一樣。既然前者性能更好,那麼顯然後者該是從右向左的了。

可以考慮再做一個測試:

<p id='all'> <span class='class1'>one</p> <span class='class1'>two</p> <span class='class1'>three</p> <span class='class1'>four</p> <p class='class2'>five</p></p>

測試 $('#all').find('p.class2') 和 $('#all p.class2')

回答2:

Sizzle選擇器引擎的主要工作就是向上兼容querySelectorAll這個API,假如所有瀏覽器都支持該API,那Sizzle就沒有存在的必要性了。sizzle選擇器一般是從右向左匹配(在不存在位置偽類的時候),Sizzle也不完全是采用從右到左,如果選擇器表達式的最左邊存在#id選擇器,就會首先對最左邊進行查詢,并將其作為下一步的執行上下文,最終達到縮小上下文的目的, $('#all.class2') 這句將先匹配所有#all元素,然后將其作為上下文在里面查找.class2 $('#all').find('.class2')而這里則先匹配#all,再從中找匹配.class2;兩種如果是使用sizzle的話,性能應該是差不多的。但是在支持querySelectorAll的瀏覽器中,可能前者沒有使用sizzle引擎,而直接調用原生的,就導致二者不一樣了。所有鄙人猜測就出現了題主的結果

標簽: CSS
相關文章:
主站蜘蛛池模板: 欧美肥婆videoxxx| 久久精品免看国产成 | 亚洲精品区在线播放一区二区 | 亚洲欧美一区二区三区国产精品 | 亚洲国产欧美在线成人aaaa | 国产午夜一级淫片 | 亚洲高清不卡 | 手机看片99 | 99久久国产免费 - 99久久国产免费 | 亚洲国产精品免费 | 中文字幕精品一区二区2021年 | 毛片美国 | 亚洲欧美日韩在线精品一区二区 | 免费看一级做a爰片久久 | 一级做a爱过程免费视频麻豆 | 国产aaa女人十八毛片 | 日本高清一本二本三本如色坊 | 欧美一级特黄特色大片免费 | 国产欧美在线观看视频 | 男人桶女人逼 | 国产日韩欧美一区二区三区综合 | 久久精品一区二区国产 | 久久只有精品视频 | 成人性欧美丨区二区三区 | 波多野结衣中文一区二区免费 | 亚洲国产成人久久综合一区77 | 免费观看欧美精品成人毛片能看的 | 国产精品7m凸凹视频分类大全 | 日本一级特黄大一片免 | 久久草在线 | a毛片免费 | 欧美曰批人成在线观看 | 性盈盈影院在线观看 | 国产三级在线视频观看 | 韩国一级淫片视频免费播放 | 欧美精品99 | 天堂视频在线免费观看 | 国产在线观看精品香蕉v区 国产在线观看免费人成小说 | 艳女伦交一级毛片 | 国产九九免费视频网站 | 一区二区三区四区视频在线观看 |