javascript之querySelector和querySelectorAll

來源:互聯網
上載者:User

其實關於querySelector和querySelectorAll的介紹說明很多。

在此主要是做個記錄。

一開始很多人都會拿jquery的選取器來跟這兩個api做對比(我也是),比較異同本來沒事,但卻使一些同學對這兩個api在瀏覽器中的實現產生了誤解,特別是再dom element上調用此api時。

下面是我的jsFiddle樣本,我就以此展開說明:

誤解就在於對$('inner').querySelectorAll('#main h4.inside')的實現理解,不少人一開始幾乎都認為是直接從div[id='inner']的孩子中進行尋找(我也是),這個#main有點礙眼。實際上它還是根據selector string從整個document上尋找,再返回屬於div[id='inner']的子節點。很多人會疑惑,那麼為什麼不按照直接按父節點找子節點的方式來實現呢?就像elem.getElementsByTagName,我的想法是靈活selector string吧。

querySelector只返回匹配的第一個元素,如果沒有匹配項,返回null。

querySelectorAll返回匹配的元素集合,如果沒有匹配項,返回空的nodelist(節點數組)。

並且返回的結果是靜態,之後對document結構的改變不會影響到之前取到的結果。

目前IE8+,ff,chrome都支援此api(IE8中的selector string只支援css2.1的)。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.