中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JavaScript中querySelector與getElementById方法的區別是什么

發布時間:2021-10-28 10:53:27 來源:億速云 閱讀:173 作者:iii 欄目:開發技術

這篇文章主要介紹“JavaScript中querySelector與getElementById方法的區別是什么”,在日常操作中,相信很多人在JavaScript中querySelector與getElementById方法的區別是什么問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”JavaScript中querySelector與getElementById方法的區別是什么”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

1. 概述

在看代碼的時候發現基本上都是用 querySelector() 和 querySelectorAll() 來獲取元素,疑惑為什么不用 getElementById()。
可能因為自己沒用過那兩個,所以并不清楚原因所在。

1.1 querySelector() 和 querySelectorAll() 的用法

querySelector() 方法

定義:   querySelector() 方法返回文檔中匹配指定 CSS 選擇器的一個元素;
注意:   querySelector() 方法僅返回匹配指定選擇器的第一個元素。如果你需要返回所有的元素,請用 querySelectorAll() 方法替代;
語法:   document.querySelector(CSS selectors);
參數值: String  必須。指定一個或多個匹配元素的 CSS 選擇器。使用它們的 id, 類, 類型, 屬性, 屬性值等來選取元素。
        對于多個選擇器,使用逗號隔開,返回一個匹配的元素。
返回值:  匹配指定 CSS 選擇器的第一個元素。 如果沒有找到,返回 null。如果指定了非法選擇器則 拋出 SYNTAX_ERR 異常。

querySelectorAll() 方法

定義:   querySelectorAll() 方法返回文檔中匹配指定 CSS 選擇器的所有元素,返回 NodeList 對象;
         NodeList 對象表示節點的集合。可以通過索引訪問,索引值從 0 開始;
提示:    可使用 NodeList 對象的 length 屬性來獲取匹配選擇器的元素屬性,然后遍歷所有元素,從而獲取想要的信息;
語法:   elementList = document.querySelectorAll(selectors);
      elementList 是一個靜態的 NodeList 類型的對象;
         selectors 是一個由逗號連接的包含一個或多個 CSS 選擇器的字符串;
參數值:  String  必須。指定一個或多個匹配 CSS 選擇器的元素。可以通過 id, class, 類型, 屬性, 屬性值等作為選擇器來獲取元素。
   多個選擇器使用逗號(,)分隔。
返回值:   一個 NodeList 對象,表示文檔中匹配指定 CSS 選擇器的所有元素。
   NodeList 是一個靜態的 NodeList 類型的對象。如果指定的選擇器不合法,則拋出一個 SYNTAX_ERR 異常。

1.2 getElement(s)Byxxxx 的用法

getElementById() 方法

定義:  getElementById() 方法可返回對擁有指定 ID 的第一個對象的引用。
  如果沒有指定 ID 的元素返回 null;
  如果存在多個指定 ID 的元素則返回第一個;
  如果需要查找到那些沒有 ID 的元素,你可以考慮通過CSS選擇器使用 querySelector();
語法: document.getElementById(elementID);
參數值: String 必須。元素ID屬性值。
返回值:  元素對象 指定ID的元素

getElementsByTagName() 方法

定義:   getElementsByTagName() 方法可返回帶有指定標簽名的對象的集合;
提示:   參數值 "*" 返回文檔的所有元素;
語法: document.getElementsByTagName(tagname)
參數: String 必須  要獲取元素的標簽名;
返回值: NodeList 對象 指定標簽名的元素集合

getElementsByClassName() 方法

定義: getElementsByClassName() 方法返回文檔中所有指定類名的元素集合,作為 NodeList 對象。
  NodeList 對象代表一個有順序的節點列表。NodeList 對象 可通過節點列表中的節點索引號來訪問表中的節點(索引號由0開始)。
提示:  可使用 NodeList 對象的 length 屬性來確定指定類名的元素個數,并循環各個元素來獲取需要的那個元素。
語法:  document.getElementsByClassName(classname)
參數:  String 必須 需要獲取的元素類名。  多個類名使用空格分隔,如 "test demo";
返回值: NodeList 對象,表示指定類名的元素集合。元素在集合中的順序以其在代碼中的出現次序排序。

2. 區別

2.1 getElement(s)Byxxxx 獲取的是動態集合,querySelector 獲取的是靜態集合

動態就是選出的元素會隨文檔改變,靜態的不會 取出來之后就和文檔的改變無關了。

示例1:

<body>
  <ul id="box">
    <li class="a">測試1</li>
    <li class="a">測試2</li>
    <li class="a">測試3</li>
  </ul>
</body>

<script type="text/javascript">
  //獲取到ul,為了之后動態的添加li
  var ul = document.getElementById('box');
  //獲取到現有ul里面的li
  var list = ul.getElementsByTagName('li');
  for(var i =0; i < list.length; i++){
    ul.appendChild(document.createElement('li')); //動態追加li
  }
</script>

上述代碼會陷入死循環,i < list.length 這個循環條件。
因為在第一次獲取到里面的 3 個 li 后,每當往 ul 里添加了新元素后,list便會更新其值,重新獲取ul里的所有li。
也就是 getElement(s)Byxxxx 獲取的是動態集合,它總會隨著 dom 結構的變化而變化。
也就是每一次調用 list 都會重新對文檔進行查詢,導致無限循環的問題。

示例1 修改:

將 for 循環條件修改為 i < 4,結果 在 ul 里新添加了4個元素,所有現在插入的 li 標簽數量是7。

<body>
  <ul id="box">
    <li class="a">測試1</li>
    <li class="a">測試2</li>
    <li class="a">測試3</li>
  </ul>
</body>

<script type="text/javascript">
  var ul = document.getElementById('box');

  var list = ul.getElementsByTagName('li');
  for(var i = 0; i < 4; i++){
    ul.appendChild(document.createElement('li'));
  }
  console.log('list.length:',list.length);
</script>

JavaScript中querySelector與getElementById方法的區別是什么

示例2:

下述代碼靜態集合體現在 .querySelectorAll(‘li') 獲取到 ul 里所有 li 后,不管后續再動態添加了多少 li,都是不會對其參數影響。

<body>
  <ul id="box">
    <li class="a">測試1</li>
    <li class="a">測試2</li>
    <li class="a">測試3</li>
  </ul>
</body>

<script type="text/javascript">
  var ul = document.querySelector('ul');

  var list = ul.querySelectorAll('li');
  for(var i = 0; i < list.length; i++){
    ul.appendChild(document.createElement('li'));
  }
  console.log('list.length:',list.length); //輸出的結果仍然是 3,不是此時 li 的數量 6
</script>

JavaScript中querySelector與getElementById方法的區別是什么

為什么要這樣設計呢?
在 W3C 規范中對 querySelectorAll 方法有明確規定:

The NodeList object returned by the querySelectorAll() method must be static ([DOM], section 8).

我們再看看在 Chrome 上面是個什么樣的情況:

document.querySelectorAll('a').toString();    // return "[object NodeList]"
document.getElementsByTagName('a').toString();    // return "[object HTMLCollection]"

HTMLCollection 在 W3C 的定義如下:

An HTMLCollection is a list of nodes. An individual node may be accessed by either ordinal index or the node's name or id attributes.Note: Collections in the HTML DOM are assumed to be live meaning that they are automatically updated when the underlying document is changed.

實際上,HTMLCollection 和 NodeList 十分相似,都是一個動態的元素集合,每次訪問都需要重新對文檔進行查詢。
區別:HTMLCollection 屬于 Document Object Model HTML 規范,而 NodeList 屬于 Document Object Model Core 規范。
這樣說有點難理解,看看下面的例子會比較好理解:

var ul = document.getElementsByTagName('ul')[0],
    lis1 = ul.childNodes,
    lis2 = ul.children;
console.log(lis1.toString(), lis1.length);    // "[object NodeList]" 11
console.log(lis2.toString(), lis2.length);    // "[object HTMLCollection]" 4

NodeList 對象會包含文檔中的所有節點,如 Element、Text 和 Comment 等;
HTMLCollection 對象只會包含文檔中的 Element 節點;
另外,HTMLCollection 對象比 NodeList 對象 多提供了一個 namedItem 方法;
因此在瀏覽器中,querySelectorAll 的返回值是一個靜態的 NodeList 對象,而 getElementsBy 系列的返回值實際上是一個 HTMLCollection 對象 。

2.2 接收的參數不同

querySelectorAll 方法接收的參數是一個 CSS 選擇符;
getElementsBy 系列接收的參數只能是單一的 className、tagName 和 name;

var c1 = document.querySelectorAll('.b1 .c');
var c2 = document.getElementsByClassName('c');
var c3 = document.getElementsByClassName('b2')[0].getElementsByClassName('c');

注意:querySelectorAll 所接收的參數是必須嚴格符合 CSS 選擇符規范的
下面這種寫法,將會拋出異常(CSS 選擇器中的元素名,類和 ID 均不能以數字為開頭)。

try {
  var e1 = document.getElementsByClassName('1a2b3c');
  var e2 = document.querySelectorAll('.1a2b3c');
} catch (e) {
  console.error(e.message);
}
console.log(e1 && e1[0].className);
console.log(e2 && e2[0].className);

2.3 瀏覽器兼容不同

querySelectorAll 已被 IE 8+、FF 3.5+、Safari 3.1+、Chrome 和 Opera 10+ 支持 ;
getElementsBy 系列,以最遲添加規范中的 getElementsByClassName 為例,IE 9+、FF 3 +、Safari 3.1+、Chrome 和 Opera 9+ 都已經支持;

2.4 querySelector 屬于 W3C 中的 Selectors API 規范 ,而 getElementsBy 系列屬于 W3C 的 DOM 規范

到此,關于“JavaScript中querySelector與getElementById方法的區別是什么”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

康保县| 天柱县| 石棉县| 关岭| 辽中县| 浠水县| 南江县| 靖州| 鄯善县| 涪陵区| 三门县| 双辽市| 定边县| 新宁县| 三明市| 怀安县| 湖南省| 乌海市| 潼南县| 连城县| 郑州市| 巨鹿县| 庐江县| 东山县| 南康市| 贵州省| 秦安县| 资讯| 宽甸| 改则县| 吉木萨尔县| 新晃| 东源县| 信阳市| 海兴县| 达州市| 徐闻县| 互助| 方城县| 津南区| 夏津县|