javascript高級選擇器querySelector和querySelectorAll

来源:http://www.cnblogs.com/chendc/archive/2016/04/06/5359565.html
-Advertisement-
Play Games

querySelector 和 querySelectorAll 方法是 W3C Selectors API 規範中定義的。他們的作用是根據 CSS 選擇器規範,便捷定位文檔中指定元素。 目前幾乎主流瀏覽器均支持了他們。包括 IE8(含) 以上版本、 Firefox、 Chrome、Safari、O ...


querySelector 和 querySelectorAll 方法是 W3C Selectors API 規範中定義的。他們的作用是根據 CSS 選擇器規範,便捷定位文檔中指定元素。

目前幾乎主流瀏覽器均支持了他們。包括 IE8(含) 以上版本、 Firefox、 Chrome、Safari、Opera。

querySelector 和 querySelectorAll 在規範中定義瞭如下介面:

module dom { [Supplemental, NoInterfaceObject] interface NodeSelector { Element querySelector(in DOMString selectors); NodeList querySelectorAll(in DOMString selectors); }; Document implements NodeSelector; DocumentFragment implements NodeSelector; Element implements NodeSelector; };

從介面定義可以看到Document、DocumentFragment、Element都實現了NodeSelector介面。即這三種類型的元素都擁有者兩個方法。querySelector和querySelectorAll的參數須是符合 css selector 的字元串。不同的是querySelector返回的是一個對象,querySelectorAll返回的一個集合(NodeList)。

獲取頁面I屬性D為test的元素:

  1. 1 document.getElementById("test");
    2 document.querySelector("#test");
    3 document.querySelectorAll("#test")[0];

     

獲取頁面class屬性為”red”的元素:

  1. document.getElementsByClassName('red')
    document.querySelector('.red')
    document.querySelectorAll('.red')

ps:

 但需要註意的是返回的nodeList集合中的元素是非實時(no-live)的,想要區別什麼是實時非實時的返回結果,請看下例:

1 <div id="container">
2     <div></div>
3     <div></div>
4 </div>

 

1 //首先選取頁面中id為container的元素
2 container=document.getElementById('#container');
3 console.log(container.childNodes.length)//結果為2
4 //然後通過代碼為其添加一個子元素
5 container.appendChild(document.createElement('div'));
6 //這個元素不但添加到頁面了,這裡的變數container也自動更新了
7 console.log(container.childNodes.length)//結果為3

 

通過上面的例子就很好地理解了什麼是會實時更新的元素。document.getElementById返回的便是實時結果,上面對其添加一個子元素後,再次獲取所有子元素個數,已經由原來的2個更新為3個(這裡不考慮有些瀏覽器比如Chrome會把空白也解析為一個子節點)。

Element.querySelector和Element.querySelectorAll和jQuery(element).find(selector)選擇器的區別:

<divid="test1"><ahref="http://www.hujuntao.com/">設計蜂巢</a></div>
<pid="bar">111</p>
<script>
var d1 = document.getElementById('test1'),
obj1 = d1.querySelector('div a'),
obj2 = d1.querySelectorAll('div a');
obj3 = $(d1).find('div a');
console.log(obj1)//<a href="http://www.hujuntao.com/">設計蜂巢</a>
console.log(obj2.length)//1
console.log(obj3)//null
</script>

querySelectorAll 在文檔內找全部符合選擇器描述的節點包括Element本身

jQuery(element).find(selector) 在文檔內找全部符合選擇器描述的節點不包括Element本身

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Atitit..css的體繫結構 1. Oocss 與 bem標準化1 1.1. 四種樣式表及六種選擇器1 1.2. 常用的css框架 amazeui bootstrap1 1.3. Css圖標1 1.4. Css的操作api1 1.5. Css ide ::2 1. Oocss 與 bem標準化 ...
  • Atitit.判斷元素是否顯示隱藏在父元素 overflow 1.1. scrollTop 指的是元素的滾動條頂端距離原生基線的高度...1 1.2. 判斷元素是否顯示隱藏在父元素 $(next).position().top》》curBaseTop= $(".listBlock_main").sc ...
  • AMD是RequireJS在推廣過程中對模塊定義的規範化產出。 非同步載入模塊,依賴前置,提前執行。 Define定義模塊 define([‘require’,’foo’],function(){return}); Require載入模塊(依賴前置) require([‘foo’,’bar’],fun... ...
  • Atitit.js模塊化 atiImport 的新特性javascript import 1. 常見的js import規範amd ,cmd ,umd1 1.1. Require更多流行3 2. atiImport3 2.1. Base url的設置4 2.2. Atiimport的使用4 2.3. ...
  • 前言 上一節我們已經把環境給搭建起來了,現在我們通過一個快速案例把angular 2.0 初步瞭解一下,後續我們會深入每一個細節,這個案例主要是一個【英雄(Hero)】列表的展示,創建,編輯。這個案例我打算分五個章節來做,第一個章節我們可以學習到angular2.0一下內容: 單項數據綁定 雙向數據 ...
  • 動畫的思路很簡單,點擊頁面上一個元素,頁面滾動到指定位置。下麵介紹一下我3個小時百度的研究成果: 首先是html部分: 先添加兩個<a>元素作為按鈕。然後對<a>元素進行補充: 接著引入jquery和寫入代碼: 需要註意: 1、寫入的代碼最好在引入的jquery語句下方 2、id一定要和<a>元素對 ...
  • 前臺代碼: @using Models; @{ Layout = "~/Views/Shared/_Layout.cshtml"; } <link type="text/css" href="~/Scripts/zTree/css/zTreeStyle/zTreeStyle.css" rel="st ...
  • 現在項目已經有了,但是要把它放到生產環境中還是有些事情要做,在這最後一節,來把它們一一搞定。 這一節其實更多是關於webpack的內容。不過要想把react用得很爽,我們需要一個現代化的構建工具。在前面幾節webpack都在默默地工作著。react全都是關於組件的,組件意味著模塊化,webpack讓 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...