成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

奇怪的querySelector和querySelectorAll

klinson / 3378人閱讀

摘要:在年的中新增了兩個和。其中返回的是單個元素,而返回的是匹配到的所有組成的。這里分別在這個元素和上調(diào)用了可以看出,使用在上的是被限制在該的范圍內(nèi)的,而在上調(diào)用的則會在全局中尋找符合條件的元素。但結(jié)果其實是選擇器正確的拿到了我們要找的,的值為。

W3C在07年的Selectors API中新增了兩個API —— querySelectorquerySelectorAll。這兩個API在文檔中的描述如下:

partial interface Document {
  Element?  querySelector(DOMString selectors);
  NodeList  querySelectorAll(DOMString selectors);
};

partial interface DocumentFragment {
  Element?  querySelector(DOMString selectors);
  NodeList  querySelectorAll(DOMString selectors);
};

partial interface Element {
  Element?  querySelector(DOMString selectors);
  NodeList  querySelectorAll(DOMString selectors);
};

從接口定義中就可以看出,Document,DocumentFragmentElement都支持querySelectorquerySelectorAll。其中querySelector返回的是單個元素,而querySelectorAll返回的是匹配到的所有DOM組成的NodeList。

構(gòu)想一下下面的HTML結(jié)構(gòu):




  
  
  JS Bin


  
Lever
Hello World!

現(xiàn)在試著用querySelector和querySelectorAll來處理DOM。

const container = document.querySelector("#container")
const name1 = container.querySelector(".name").innerText
const name2 = document.querySelector("#container > .name").innerText
console.log(name1, name2) // Lever Lever

這里分別在"#container"這個元素和document上調(diào)用了querySelector,可以看出,使用在Element上的querySelector是被限制在該Element的范圍內(nèi)的,而在document上調(diào)用的querySelector則會在全局中尋找符合條件的元素。

const name3 = container.querySelector(".container > .name").innerText

現(xiàn)在猜猜,name3會輸出什么。如果經(jīng)常使用jQuery的話,很容易認(rèn)為這樣的選擇器不會匹配到任何DOM,因為在“#container”的子元素中沒有匹配的DOM。但結(jié)果其實是選擇器正確的拿到了我們要找的DOM,name3的值為“Lever”。

不要懷疑,這不是瀏覽器的bug,規(guī)范中是這樣描述的:

Even though the method is invoked on an element, selectors are still evaluated in the context of the entire document. In the following example, the method will still match the div element"s child p element, even though the body element is not a descendant of the div element itself.

var div = document.getElementById("bar");
var p = div.querySelector("body p");

按照規(guī)范的意思,在Element下的querySelector同樣會在整個document下尋找符合條件的選擇器,然后才會將結(jié)果中屬于Element子樹的DOM截取出來。

這樣看來,也就能解釋為什么獲取name3的選擇器仍然會起作用了。

還需要注意的是,通過querySelectorAll選取出來的NodeList是靜態(tài)的,因此任何對DOM的增刪改的操作,不會影響到已經(jīng)查詢出來的NodeList的結(jié)果。

與本文的相關(guān)代碼都放到了JSBin上。

參考資料:Selectors API Level 1

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/81522.html

相關(guān)文章

  • 你所不了解querySelector

    摘要:而事實上,它會在的子代元素中匹配查詢條件。它們并不會相對于任何特定的元素,甚至不會相對于調(diào)用的元素。偽選擇器是相對當(dāng)前作用域進(jìn)行匹配的。它們是和的替代方法,存在父節(jié)點上。了解像這些坑很重要,因為從它們的行為中很難了解它們的實質(zhì)特性。 原文鏈接地址:http://blog.lxjwlt.com/front-...筆者整理筆記: 1.API介紹 先看看MDN上怎么介紹這個API的:概述返回...

    freewolf 評論0 收藏0
  • 獲取網(wǎng)頁指定元素原生方法回顧

    摘要:瀏覽器原生提供的幾個找到元素的方法為網(wǎng)頁全局唯一。匹配包含的元素匹配包含和的元素級聯(lián)用法和相似返回一個。以上返回數(shù)組的方法,返回的都是的。 那是個夜黑風(fēng)高的夜晚,我遇到了一個按鈕: 搜索 嗯,我要選中它,我敲下了一行代碼: const submitButton = document.querySelector(button[type=submit]); 這對于精通 document.q...

    URLOS 評論0 收藏0
  • JavaScript DOM擴(kuò)展——“選擇符API元素遍歷”注意要點

    摘要:實際上,的核心就是通過選擇符查詢文檔取得元素的引用。方法該方法接收一個選擇符,返回的是所有匹配的元素而不僅僅是一個元素。而其底層實現(xiàn)則類似于一組元素的快照,而非不斷對文檔進(jìn)行搜索的動態(tài)查詢。 選擇符API Selector API Level1 的核心就是兩個方法:querySelector()和querySelectorAll()。實際上,jQuery的核心就是通過CSS選擇符查詢D...

    justCoding 評論0 收藏0
  • 通過DOM API 查找節(jié)點

    摘要:我們可以通過來檢查某個節(jié)點是否有子節(jié)點。通過可以用來取得父元素,返回值可能會是一個元素節(jié)點根節(jié)點或節(jié)點。與類似,通過可以取得同層之間的下一個節(jié)點,如果已經(jīng)是最后一個節(jié)點,則返回。在上一篇的分享當(dāng)中,我們簡單介紹了BOM 與DOM,也了解到JavaScript 是怎么通過它們提供的方法來與瀏覽器進(jìn)行溝通。 當(dāng)一個網(wǎng)頁被載入到瀏覽器時,瀏覽器會首先分析這個HTML 文檔,然后會依照這份HTML ...

    shengguo 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<