亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Javascript ParentNode和ChildNode接口原理解析

瀏覽:79日期:2023-11-07 13:29:12

ParentNode 接口,ChildNode 接口

節點對象除了繼承 Node 接口以外,還擁有其他接口。ParentNode接口表示當前節點是一個父節點,提供一些處理子節點的方法。ChildNode接口表示當前節點是一個子節點,提供一些相關方法。

ParentNode 接口

如果當前節點是父節點,就會混入了(mixin)ParentNode接口。由于只有元素節點(element)、文檔節點(document)和文檔片段節點(documentFragment)擁有子節點,因此只有這三類節點會擁有ParentNode接口。

ParentNode.childrenchildren屬性返回一個HTMLCollection實例,成員是當前節點的所有元素子節點。該屬性只讀。

下面是遍歷某個節點的所有元素子節點的示例。

for (var i = 0; i < el.children.length; i++) { // ...}

注意,children屬性只包括元素子節點,不包括其他類型的子節點(比如文本子節點)。如果沒有元素類型的子節點,返回值HTMLCollection實例的length屬性為0。

另外,HTMLCollection是動態集合,會實時反映 DOM 的任何變化。

ParentNode.firstElementChild

firstElementChild屬性返回當前節點的第一個元素子節點。如果沒有任何元素子節點,則返回null。

document.firstElementChild.nodeName// 'HTML'

上面代碼中,document節點的第一個元素子節點是<HTML>。

ParentNode.lastElementChildlastElementChild屬性返回當前節點的最后一個元素子節點,如果不存在任何元素子節點,則返回null。

document.lastElementChild.nodeName// 'HTML'

上面代碼中,document節點的最后一個元素子節點是<HTML>(因為document只包含這一個元素子節點)。

ParentNode.childElementCountchildElementCount屬性返回一個整數,表示當前節點的所有元素子節點的數目。如果不包含任何元素子節點,則返回0。

document.body.childElementCount // 13

ParentNode.append(),ParentNode.prepend()

append方法為當前節點追加一個或多個子節點,位置是最后一個元素子節點的后面。

該方法不僅可以添加元素子節點,還可以添加文本子節點。

var parent = document.body;// 添加元素子節點var p = document.createElement(’p’);parent.append(p);// 添加文本子節點parent.append(’Hello’);// 添加多個元素子節點var p1 = document.createElement(’p’);var p2 = document.createElement(’p’);parent.append(p1, p2);// 添加元素子節點和文本子節點var p = document.createElement(’p’);parent.append(’Hello’, p);

注意,該方法沒有返回值。

prepend方法為當前節點追加一個或多個子節點,位置是第一個元素子節點的前面。它的用法與append方法完全一致,也是沒有返回值。

ChildNode 接口

如果一個節點有父節點,那么該節點就擁有了ChildNode接口。

ChildNode.remove()remove方法用于從父節點移除當前節點。

el.remove()

上面代碼在 DOM 里面移除了el節點。

ChildNode.before(),ChildNode.after()before方法用于在當前節點的前面,插入一個或多個同級節點。兩者擁有相同的父節點。

注意,該方法不僅可以插入元素節點,還可以插入文本節點。

var p = document.createElement(’p’);var p1 = document.createElement(’p’);// 插入元素節點el.before(p);// 插入文本節點el.before(’Hello’);// 插入多個元素節點el.before(p, p1);// 插入元素節點和文本節點el.before(p, ’Hello’);

after方法用于在當前節點的后面,插入一個或多個同級節點,兩者擁有相同的父節點。用法與before方法完全相同。

ChildNode.replaceWith()replaceWith方法使用參數節點,替換當前節點。參數可以是元素節點,也可以是文本節點。

var span = document.createElement(’span’);el.replaceWith(span);

上面代碼中,el節點將被span節點替換。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产美女无遮挡免费视频网站 | 青青青青久久久久国产的 | 欧美一级α片毛片免费观看 | 免费黄色在线网址 | 爱福利视频一区二区 | 国产伦码精品一区二区三区 | 国产片自拍 | 亚洲欧美日韩中文字幕在线不卡 | 一级性生活视频 | 国产视频二区在线观看 | 国产日韩欧美精品一区二区三区 | 一级做a爱片特黄在线观看 一级做a爱片特黄在线观看免费看 | 精品国产亚洲一区二区在线3d | 2022日本卡一卡二新区 | 一级免费黄色 | 综合 欧美 亚洲日本 | 日韩毛片欧美一级a网站 | 国产一区二区不卡免费观在线 | 欧美成人性毛片免费版 | 欧美激情一区二区三区蜜桃视频 | 亚洲成人在线播放视频 | 色婷婷久久综合中文网站 | 国产亚洲欧美久久久久 | 欧美在线黄 | 高清 国产 日韩 欧美 | 人人狠狠综合久久亚洲88 | 欧美日韩一区二区在线观看 | 久久精品影院一区二区三区 | 色综合综合色 | 日韩精品在线视频 | 国产亚洲一区二区三区啪 | 中文字幕在线色 | 国产一区二区三区成人久久片 | 日本在线网站 | 久热香蕉在线视频 | 国产成人18黄网站免费 | 久久久精品久久久久久久久久久 | 日本护士一级毛片在线播放 | 在线观看av网站永久 | 日本特黄特色高清免费视频 | 男女啪啪免费观看网站 |