學(xué)習(xí)JS中的DOM節(jié)點(diǎn)以及操作
DOM操作在JS中可以說是非常常見了吧,很多網(wǎng)頁的小功能的實(shí)現(xiàn),比如一些元素的增刪操作等都可以用JS來實(shí)現(xiàn)。那么在DOM中我們需要知道些什么才能完成一些功能的實(shí)現(xiàn)呢?今天這篇文章就先簡單的帶大家入一下JS中DOM操作的門吧??!
一、DOM樹的節(jié)點(diǎn)
1、 DOM節(jié)點(diǎn)分為三大類: 元素節(jié)點(diǎn)(標(biāo)簽節(jié)點(diǎn))、屬性節(jié)點(diǎn)和文本節(jié)點(diǎn)。
屬性節(jié)點(diǎn)和文本節(jié)點(diǎn)都屬于元素節(jié)點(diǎn)的子節(jié)點(diǎn)。 因此操作時(shí),需先選中元素節(jié)點(diǎn),再修改屬性和文本。
【查看元素節(jié)點(diǎn)】
1、 使用getElement系列方法:
具體的HTML代碼如下圖:

//通過ID來查看元素屬性
var li = document.getElementById("first");
//通過類名來查看元素屬性
var lis1 = document.getElementsByClassName("cls");
//通過名字來查看元素屬性
var lis2 = document.getElementsByName("name");
//通過標(biāo)簽名來查看元素屬性
var lis3 = document.getElementsByTagName("li");
注意事項(xiàng):
① ID不能重名,如果ID重復(fù),只能取到第一個(gè)。
② 獲取元素節(jié)點(diǎn)時(shí),必須等到DOM樹加載完成后才能獲取。
兩種處理方式:
a.將JS寫在文檔最后;
b.將代碼寫入window.onload函數(shù)中;
③ 通過getElements系列取到的為數(shù)組格式,操作時(shí)必須取到其中的每一個(gè)元素,才能進(jìn)行操作,而不能直接對數(shù)組進(jìn)行操作。
document.getElementsByTagName("li")[0].click = function(){}
④ 這一系列方法,也可以先選中一個(gè)DOM節(jié)點(diǎn),在從選中的DOM節(jié)點(diǎn)中,選擇需要的節(jié)點(diǎn):
document.getElementById("div1").getElementsByTagName("li");
【通過querySelector系列方法】
① 傳入一個(gè)選擇器名稱,返回第一個(gè)找到的元素。 通常用于查找ID:
var dq1 = document.querySelector("#id");
② 傳入一個(gè)選擇器名稱,返回所有找到的元素,無論找到幾個(gè),都返回?cái)?shù)組格式。這種方法比較全能,不管什么屬性都可以準(zhǔn)確地找到。
var dqs1 = document.querySelectorAll("#div1 li");
【查看\設(shè)置屬性節(jié)點(diǎn)】
1、 查看屬性節(jié)點(diǎn):.getAttribute("屬性名");
2、 設(shè)置屬性節(jié)點(diǎn):.setAttribute("屬性名","屬性值");
注意事項(xiàng):.setAttribute() 在老版本IE中會(huì)存在兼容性問題,可以使用.符號(hào)代替。
【JS修改CSS的多種方式】
1、 使用setAttribute設(shè)置class和style。
document.getElementById("first").setAttribute("class","class1");
document.getElementById("first").setAttribute("style","color:red;");
2、使用.className添加一個(gè)class選擇器。
document.getElementById("first").className = "class1";
3、 使用.style.樣式 直接修改單個(gè)樣式。 注意樣式名必須使用駝峰命名法。
document.getElementById("first").style.fontSize = "18px";
4、 使用.style 或 .style.cssText 添加一串行級(jí)樣式:
// IE不兼容
document.getElementById("first").style = "color:red;";
//所有瀏覽器兼容
document.getElementById("first").style.cssText = "color:red;";
【查看/設(shè)置文本節(jié)點(diǎn)】
1、.innerHTML: 取到或設(shè)置一個(gè)節(jié)點(diǎn)中的HTML代碼。
2、.innerText: 取到或設(shè)置一個(gè)節(jié)點(diǎn)中的文本,不能設(shè)置HTML代碼。
二、層次節(jié)點(diǎn)操作
1. .childNodes: 獲取當(dāng)前節(jié)點(diǎn)的所有子節(jié)點(diǎn)(包括元素節(jié)點(diǎn)和文本節(jié)點(diǎn))。
.children: 獲取當(dāng)前節(jié)點(diǎn)的所有元素子節(jié)點(diǎn)(不包含文本節(jié)點(diǎn))。
2. .parentNode: 獲取當(dāng)前節(jié)點(diǎn)的父節(jié)點(diǎn)。
3. .firstChild: 獲取第一個(gè)子節(jié)點(diǎn),包括回車等文本節(jié)點(diǎn);
.firstElementChild: 獲取第一個(gè)元素節(jié)點(diǎn)。 不含文本節(jié)點(diǎn);
.lastChild: 獲取最后一個(gè)子節(jié)點(diǎn),包括回車等文本節(jié)點(diǎn);
.lastElementChild: 獲取最后一個(gè)子節(jié)點(diǎn),不含文本節(jié)點(diǎn);
4. .previousSibling: 獲取當(dāng)前節(jié)點(diǎn)的前一個(gè)兄弟節(jié)點(diǎn),包括文本節(jié)點(diǎn);
.previousElementSibling: 獲取當(dāng)前節(jié)點(diǎn)的前一個(gè)元素兄弟節(jié)點(diǎn);
.nextSibling:獲取當(dāng)前節(jié)點(diǎn)的后一個(gè)兄弟節(jié)點(diǎn),包括文本節(jié)點(diǎn);
.nextElementSibling:獲取當(dāng)前節(jié)點(diǎn)的后一個(gè)元素兄弟節(jié)點(diǎn);
5. .attributes: 獲取當(dāng)前節(jié)點(diǎn)的所有屬性節(jié)點(diǎn)。 返回?cái)?shù)組格式。
【創(chuàng)建并新增節(jié)點(diǎn)】
1. document.createElement("標(biāo)簽名"): 創(chuàng)建一個(gè)新節(jié)點(diǎn),并將創(chuàng)建的新節(jié)點(diǎn)返回。
需要配合.setAttribute()為新節(jié)點(diǎn)設(shè)置屬性。
2. 父節(jié)點(diǎn).insertBefore(新節(jié)點(diǎn),目標(biāo)節(jié)點(diǎn)): 在父節(jié)點(diǎn)中,將新節(jié)點(diǎn)插入到目標(biāo)節(jié)點(diǎn)之前。
父節(jié)點(diǎn).appendChild(新節(jié)點(diǎn)): 在父節(jié)點(diǎn)的內(nèi)部最后,插入一個(gè)新節(jié)點(diǎn)。
3. 源節(jié)點(diǎn).cloneNode(true): 克隆一個(gè)節(jié)點(diǎn)。
傳入true表示克隆源節(jié)點(diǎn)以及源節(jié)點(diǎn)的所有子節(jié)點(diǎn);
傳入false或不傳,表示只克隆當(dāng)前節(jié)點(diǎn),而不克隆子節(jié)點(diǎn)。
【刪除、替換節(jié)點(diǎn)】
1. 父節(jié)點(diǎn).removeChild(子節(jié)點(diǎn)): 從父節(jié)點(diǎn)中,刪除指定子節(jié)點(diǎn)。
2. 父節(jié)點(diǎn).replaceChild(新節(jié)點(diǎn),老節(jié)點(diǎn)): 從父節(jié)點(diǎn)中,用新節(jié)點(diǎn)替換老節(jié)點(diǎn)。
相關(guān)文章
webapi根據(jù)id獲取元素的實(shí)現(xiàn)思路
掌握document.getElementById() 根據(jù)id獲取元素,在頁面畫出一個(gè)寬200 高200 粉色的盒子, 在控制臺(tái)打印這個(gè)盒子,接到這樣的需求如何處理呢,下面小編給大家分享webapi根據(jù)id獲取元素的實(shí)現(xiàn)思路,感興趣的朋友一起看看吧2024-02-02
JS+canvas畫布實(shí)現(xiàn)炫酷的旋轉(zhuǎn)星空效果示例
這篇文章主要介紹了JS+canvas畫布實(shí)現(xiàn)炫酷的旋轉(zhuǎn)星空效果,結(jié)合實(shí)例形式分析了js結(jié)合HTML5 canvas圖形繪制與數(shù)值計(jì)算相關(guān)操作技巧,需要的朋友可以參考下2019-02-02
JavaScript實(shí)現(xiàn)獲取select下拉框中第一個(gè)值的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)獲取select下拉框中第一個(gè)值的方法,涉及javascript針對頁面元素屬性的相關(guān)獲取操作技巧,需要的朋友可以參考下2018-02-02
javascript中刪除指定數(shù)組中指定的元素的代碼
已知一個(gè)數(shù)組,我們想用指定的方法對數(shù)組中的元素進(jìn)行逐一操作。需要的朋友可以參考下。2011-02-02
JavaScript實(shí)現(xiàn)alert彈框效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)alert彈框效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11
JavaScript隱式類型轉(zhuǎn)換代碼實(shí)例
這篇文章主要介紹了JavaScript隱式類型轉(zhuǎn)換代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-05-05
JS表格組件BootstrapTable行內(nèi)編輯解決方案x-editable
這篇文章主要介紹了JS組件系列BootstrapTable行內(nèi)編輯解決方案:x-editable,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09
javascript實(shí)現(xiàn)復(fù)選框超過限制即彈出警告框的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)復(fù)選框超過限制即彈出警告框的方法,涉及復(fù)選框及警告框的操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02

