亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript中的DOM遍歷詳解

 更新時(shí)間:2023年09月24日 15:06:48   作者:托兒所夜十三  
文檔對(duì)象模型 (DOM) 表示 HTML 文檔的結(jié)構(gòu),導(dǎo)航或“遍歷”此結(jié)構(gòu)是 Web 開發(fā)的基本方面,使開發(fā)人員能夠在網(wǎng)頁(yè)上選擇、修改、刪除或添加內(nèi)容,本文深入研究了使用 JavaScript 進(jìn)行 DOM 遍歷的藝術(shù),提供了一個(gè)強(qiáng)大的工具包來(lái)處理各種遍歷場(chǎng)景

介紹

文檔對(duì)象模型 (DOM) 表示 HTML 文檔的結(jié)構(gòu)。導(dǎo)航或“遍歷”此結(jié)構(gòu)是 Web 開發(fā)的基本方面,使開發(fā)人員能夠在網(wǎng)頁(yè)上選擇、修改、刪除或添加內(nèi)容。這本綜合指南深入研究了使用 JavaScript 進(jìn)行 DOM 遍歷的藝術(shù),提供了一個(gè)強(qiáng)大的工具包來(lái)處理各種遍歷場(chǎng)景。

1. DOM基礎(chǔ)選擇器

讓我們回顧一下一些基本的 DOM 選擇器。

  • getElementById():返回對(duì)具有指定 ID 的第一個(gè)元素的引用。
const header = document.getElementById('header');
  • getElementsByClassName():返回具有給定類名的元素的實(shí)時(shí) HTMLCollection。
const buttons = document.getElementsByClassName('btn');
  • getElementsByTagName():返回具有給定標(biāo)簽名稱的元素的實(shí)時(shí) HTMLCollection。
const paragraphs = document.getElementsByTagName('p');
  • querySelector():返回與指定 CSS 選擇器匹配的第一個(gè)元素。
const mainImage = document.querySelector('.main-image');
  • querySelectorAll():返回一個(gè)靜態(tài) NodeList,表示與指定 CSS 選擇器匹配的元素。
const listItems = document.querySelectorAll('ul li');

2. 父母、子女和兄弟姐妹的關(guān)系

DOM 遍歷的核心是節(jié)點(diǎn)之間的關(guān)系。

2.1. 父節(jié)點(diǎn)

  • ParentNode:返回指定元素的父節(jié)點(diǎn)。
const parentOfButton = document.querySelector('.btn').parentNode;

2.2. 子節(jié)點(diǎn)

  • firstChild & lastChild:分別返回節(jié)點(diǎn)的第一個(gè)和最后一個(gè)子節(jié)點(diǎn)。
const firstChildOfDiv = document.querySelector('div').firstChild;
const lastChildOfDiv = document.querySelector('div').lastChild;
  • Children:返回元素子元素的 HTMLCollection(不包括文本和注釋節(jié)點(diǎn))。
const divChildren = document.querySelector('div').children;
  • firstElementChildlastElementChild是類似于firstChildlastChild的DOM屬性,但嚴(yán)格返回元素節(jié)點(diǎn)。
const firstElementChildOfDiv = document.querySelector('div').firstElementChild;

2.3. 兄弟節(jié)點(diǎn)

  • nextSibling & previousSibling:分別返回元素的下一個(gè)和上一個(gè)同級(jí)元素。
const nextToButton = document.querySelector('.btn').nextSibling;
const prevToButton = document.querySelector('.btn').previousSibling;
  • nextElementSiblingpreviousElementSibling是與nextSiblingpreviousSibling類似的DOM屬性,但嚴(yán)格用于元素節(jié)點(diǎn)。
const nextElementToButton = document.querySelector('.btn').nextElementSibling;

3. 遍歷方法

3.1. 節(jié)點(diǎn)迭代

  • childNodes:返回子節(jié)點(diǎn)的 NodeList。
const listNodes = document.querySelector('ul').childNodes;

3.2. 過濾元素

用于Array.prototype.filter根據(jù)條件過濾節(jié)點(diǎn)。

const listItems = document.querySelector('ul').children;
const redItems = [...listItems].filter(item => item.style.color === 'red');

4. DOM 遍歷事件

將事件偵聽器與遍歷方法相結(jié)合來(lái)創(chuàng)建交互式元素。

document.querySelector('.btn').addEventListener('click', function(e) {
  const nextElement = e.target.nextElementSibling;
  if (nextElement) {
    nextElement.style.display = 'none';
  }
});

5. 高級(jí)遍歷技術(shù)

5.1. 遞歸遍歷

遞歸遍歷整個(gè) DOM 樹。當(dāng)深度未知時(shí),此方法很有用:

function traverseDOM(node) {
  console.log(node);
  const children = node.children;
  for (let child of children) {
    traverseDOM(child);
  }
}
traverseDOM(document.body);

5.2. 向上遍歷DOM樹

在某些情況下,可能需要查找具有特定選擇器的父元素:

function findAncestor(el, selector) {
  while ((el = el.parentElement) && !el.matches(selector));
  return el;
}
const listItem = document.querySelector('li');
const containingDiv = findAncestor(listItem, 'div');

掌握 DOM 遍歷對(duì)于任何全?;蚯岸碎_發(fā)人員來(lái)說都是至關(guān)重要的。JavaScript 提供了大量的方法和屬性來(lái)導(dǎo)航 DOM 的復(fù)雜關(guān)系。

以上就是JavaScript中的DOM遍歷詳解的詳細(xì)內(nèi)容,更多關(guān)于JavaScript DOM遍歷的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • IE關(guān)閉時(shí)判斷及AJAX注銷案例學(xué)習(xí)

    IE關(guān)閉時(shí)判斷及AJAX注銷案例學(xué)習(xí)

    當(dāng)關(guān)閉系統(tǒng)時(shí)會(huì)提示:你確定要退出系統(tǒng)嗎?退出請(qǐng)按'離開此頁(yè)'接下來(lái)將講解下IE關(guān)閉判斷及AJAX注銷,感興趣的你可不要錯(cuò)過了哈,希望本例對(duì)你學(xué)習(xí)ajax有所幫助
    2013-02-02
  • 關(guān)于document.cookie的使用javascript

    關(guān)于document.cookie的使用javascript

    構(gòu)造通用的cookie處理函數(shù) cookie的處理過程比較復(fù)雜,并具有一定的相似性。因此可以定義幾個(gè)函數(shù)來(lái)完成cookie的通用操作,從而實(shí)現(xiàn)代碼的復(fù)用。
    2010-10-10
  • 詳解Js模板引擎(TrimPath)

    詳解Js模板引擎(TrimPath)

    本文詳細(xì)介紹了在頁(yè)面中引用template.js文件之后,具體的使用方法及實(shí)例,有需要的朋友可以參考下
    2016-11-11
  • JavaScript各類型的關(guān)系圖解

    JavaScript各類型的關(guān)系圖解

    這篇文章主要通過一張圖讓你看懂JavaScript各類型的關(guān)系,需要的朋友可以參考下
    2015-10-10
  • 微信小程序集成前端日志庫(kù)的詳細(xì)記錄

    微信小程序集成前端日志庫(kù)的詳細(xì)記錄

    這篇文章主要給大家介紹了關(guān)于微信小程序集成前端日志庫(kù)的詳細(xì)記錄,文中通過代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用微信小程序具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-07-07
  • 最新評(píng)論