Javascript ParentNode和ChildNode接口原理解析
ParentNode 接口,ChildNode 接口
節(jié)點(diǎn)對(duì)象除了繼承 Node 接口以外,還擁有其他接口。ParentNode接口表示當(dāng)前節(jié)點(diǎn)是一個(gè)父節(jié)點(diǎn),提供一些處理子節(jié)點(diǎn)的方法。ChildNode接口表示當(dāng)前節(jié)點(diǎn)是一個(gè)子節(jié)點(diǎn),提供一些相關(guān)方法。
ParentNode 接口
如果當(dāng)前節(jié)點(diǎn)是父節(jié)點(diǎn),就會(huì)混入了(mixin)ParentNode接口。由于只有元素節(jié)點(diǎn)(element)、文檔節(jié)點(diǎn)(document)和文檔片段節(jié)點(diǎn)(documentFragment)擁有子節(jié)點(diǎn),因此只有這三類節(jié)點(diǎn)會(huì)擁有ParentNode接口。
ParentNode.children
children屬性返回一個(gè)HTMLCollection實(shí)例,成員是當(dāng)前節(jié)點(diǎn)的所有元素子節(jié)點(diǎn)。該屬性只讀。
下面是遍歷某個(gè)節(jié)點(diǎn)的所有元素子節(jié)點(diǎn)的示例。
for (var i = 0; i < el.children.length; i++) { // ... }
注意,children屬性只包括元素子節(jié)點(diǎn),不包括其他類型的子節(jié)點(diǎn)(比如文本子節(jié)點(diǎn))。如果沒(méi)有元素類型的子節(jié)點(diǎn),返回值HTMLCollection實(shí)例的length屬性為0。
另外,HTMLCollection是動(dòng)態(tài)集合,會(huì)實(shí)時(shí)反映 DOM 的任何變化。
ParentNode.firstElementChild
firstElementChild屬性返回當(dāng)前節(jié)點(diǎn)的第一個(gè)元素子節(jié)點(diǎn)。如果沒(méi)有任何元素子節(jié)點(diǎn),則返回null。
document.firstElementChild.nodeName
// "HTML"
上面代碼中,document節(jié)點(diǎn)的第一個(gè)元素子節(jié)點(diǎn)是<HTML>。
ParentNode.lastElementChild
lastElementChild屬性返回當(dāng)前節(jié)點(diǎn)的最后一個(gè)元素子節(jié)點(diǎn),如果不存在任何元素子節(jié)點(diǎn),則返回null。
document.lastElementChild.nodeName
// "HTML"
上面代碼中,document節(jié)點(diǎn)的最后一個(gè)元素子節(jié)點(diǎn)是<HTML>(因?yàn)閐ocument只包含這一個(gè)元素子節(jié)點(diǎn))。
ParentNode.childElementCount
childElementCount屬性返回一個(gè)整數(shù),表示當(dāng)前節(jié)點(diǎn)的所有元素子節(jié)點(diǎn)的數(shù)目。如果不包含任何元素子節(jié)點(diǎn),則返回0。
document.body.childElementCount // 13
ParentNode.append(),ParentNode.prepend()
append方法為當(dāng)前節(jié)點(diǎn)追加一個(gè)或多個(gè)子節(jié)點(diǎn),位置是最后一個(gè)元素子節(jié)點(diǎn)的后面。
該方法不僅可以添加元素子節(jié)點(diǎn),還可以添加文本子節(jié)點(diǎn)。
var parent = document.body; // 添加元素子節(jié)點(diǎn) var p = document.createElement('p'); parent.append(p); // 添加文本子節(jié)點(diǎn) parent.append('Hello'); // 添加多個(gè)元素子節(jié)點(diǎn) var p1 = document.createElement('p'); var p2 = document.createElement('p'); parent.append(p1, p2); // 添加元素子節(jié)點(diǎn)和文本子節(jié)點(diǎn) var p = document.createElement('p'); parent.append('Hello', p);
注意,該方法沒(méi)有返回值。
prepend方法為當(dāng)前節(jié)點(diǎn)追加一個(gè)或多個(gè)子節(jié)點(diǎn),位置是第一個(gè)元素子節(jié)點(diǎn)的前面。它的用法與append方法完全一致,也是沒(méi)有返回值。
ChildNode 接口
如果一個(gè)節(jié)點(diǎn)有父節(jié)點(diǎn),那么該節(jié)點(diǎn)就擁有了ChildNode接口。
ChildNode.remove()
remove方法用于從父節(jié)點(diǎn)移除當(dāng)前節(jié)點(diǎn)。
el.remove()
上面代碼在 DOM 里面移除了el節(jié)點(diǎn)。
ChildNode.before(),ChildNode.after()
before方法用于在當(dāng)前節(jié)點(diǎn)的前面,插入一個(gè)或多個(gè)同級(jí)節(jié)點(diǎn)。兩者擁有相同的父節(jié)點(diǎn)。
注意,該方法不僅可以插入元素節(jié)點(diǎn),還可以插入文本節(jié)點(diǎn)。
var p = document.createElement('p'); var p1 = document.createElement('p'); // 插入元素節(jié)點(diǎn) el.before(p); // 插入文本節(jié)點(diǎn) el.before('Hello'); // 插入多個(gè)元素節(jié)點(diǎn) el.before(p, p1); // 插入元素節(jié)點(diǎn)和文本節(jié)點(diǎn) el.before(p, 'Hello');
after方法用于在當(dāng)前節(jié)點(diǎn)的后面,插入一個(gè)或多個(gè)同級(jí)節(jié)點(diǎn),兩者擁有相同的父節(jié)點(diǎn)。用法與before方法完全相同。
ChildNode.replaceWith()
replaceWith方法使用參數(shù)節(jié)點(diǎn),替換當(dāng)前節(jié)點(diǎn)。參數(shù)可以是元素節(jié)點(diǎn),也可以是文本節(jié)點(diǎn)。
var span = document.createElement('span'); el.replaceWith(span);
上面代碼中,el節(jié)點(diǎn)將被span節(jié)點(diǎn)替換。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解使用jest對(duì)vue項(xiàng)目進(jìn)行單元測(cè)試
- SpringBoot 整合Jest實(shí)例代碼講解
- 基于Spring Data Jest的Elasticsearch數(shù)據(jù)統(tǒng)計(jì)示例
- 詳解如何在項(xiàng)目中使用jest測(cè)試react native組件
- 詳解Jest結(jié)合Vue-test-utils使用的初步實(shí)踐
- vue-resource:jsonp請(qǐng)求百度搜索的接口示例
- 在Koa.js中實(shí)現(xiàn)文件上傳的接口功能
- JS 封裝父頁(yè)面子頁(yè)面交互接口的實(shí)例代碼
- 用js簡(jiǎn)單提供增刪改查接口
- 詳解Nodejs get獲取遠(yuǎn)程服務(wù)器接口數(shù)據(jù)
- 使用 Jest 和 Supertest 進(jìn)行接口端點(diǎn)測(cè)試實(shí)例詳解
相關(guān)文章
利用js+css+html實(shí)現(xiàn)固定table的列頭不動(dòng)
本文分享了利用js+css+html實(shí)現(xiàn)固定table的列頭不動(dòng)的實(shí)例代碼。小編認(rèn)為具有很好的參考價(jià)值,感興趣的朋友可以看下2016-12-12服務(wù)端渲染nextjs項(xiàng)目接入經(jīng)驗(yàn)總結(jié)分析
這篇文章主要為大家介紹了服務(wù)端渲染nextjs項(xiàng)目接入經(jīng)驗(yàn)總結(jié)分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-11-11JavaScript使用RegExp進(jìn)行正則匹配的方法
這篇文章主要介紹了JavaScript使用RegExp進(jìn)行正則匹配的方法,實(shí)例分析了RegExp對(duì)象在進(jìn)行正則匹配時(shí)的相關(guān)使用技巧,需要的朋友可以參考下2015-07-07JavaScript 斐波那契數(shù)列 倒序輸出 輸出100以內(nèi)的質(zhì)數(shù)代碼實(shí)例
這篇文章主要介紹了JavaScript 斐波那契數(shù)列 倒序輸出 輸出100以內(nèi)的質(zhì)數(shù)代碼實(shí)例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09小程序開發(fā)之uniapp引入iconfont圖標(biāo)以及使用方式
uniapp本身是有icon組件的,但由于icon組件各端表現(xiàn)存在差異,所以我們可以通過(guò)使用iconfont的字體圖標(biāo)來(lái)彌補(bǔ)這些差異,下面這篇文章主要給大家介紹了關(guān)于小程序開發(fā)之uniapp引入iconfont圖標(biāo)以及使用方式的相關(guān)資料,需要的朋友可以參考下2022-11-11