欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

學習JS中的DOM節(jié)點以及操作

 更新時間:2018年04月30日 12:54:35   作者:楊。。  
本篇文章給大家整理了關于JS中DOM節(jié)點的相關知識點以及代碼實例,有興趣的朋友可以跟著學習下。

DOM操作在JS中可以說是非常常見了吧,很多網(wǎng)頁的小功能的實現(xiàn),比如一些元素的增刪操作等都可以用JS來實現(xiàn)。那么在DOM中我們需要知道些什么才能完成一些功能的實現(xiàn)呢?今天這篇文章就先簡單的帶大家入一下JS中DOM操作的門吧??!

一、DOM樹的節(jié)點

1、 DOM節(jié)點分為三大類: 元素節(jié)點(標簽節(jié)點)、屬性節(jié)點和文本節(jié)點。

屬性節(jié)點和文本節(jié)點都屬于元素節(jié)點的子節(jié)點。 因此操作時,需先選中元素節(jié)點,再修改屬性和文本。

【查看元素節(jié)點】

1、 使用getElement系列方法:

具體的HTML代碼如下圖:

//通過ID來查看元素屬性
var li = document.getElementById("first"); 
//通過類名來查看元素屬性
var lis1 = document.getElementsByClassName("cls");
//通過名字來查看元素屬性
var lis2 = document.getElementsByName("name");
//通過標簽名來查看元素屬性
var lis3 = document.getElementsByTagName("li");

注意事項:

① ID不能重名,如果ID重復,只能取到第一個。

② 獲取元素節(jié)點時,必須等到DOM樹加載完成后才能獲取。

兩種處理方式:

a.將JS寫在文檔最后;

b.將代碼寫入window.onload函數(shù)中;

③ 通過getElements系列取到的為數(shù)組格式,操作時必須取到其中的每一個元素,才能進行操作,而不能直接對數(shù)組進行操作。

document.getElementsByTagName("li")[0].click = function(){}

④ 這一系列方法,也可以先選中一個DOM節(jié)點,在從選中的DOM節(jié)點中,選擇需要的節(jié)點:

document.getElementById("div1").getElementsByTagName("li");

【通過querySelector系列方法】

① 傳入一個選擇器名稱,返回第一個找到的元素。 通常用于查找ID:

var dq1 = document.querySelector("#id");

② 傳入一個選擇器名稱,返回所有找到的元素,無論找到幾個,都返回數(shù)組格式。這種方法比較全能,不管什么屬性都可以準確地找到。

var dqs1 = document.querySelectorAll("#div1 li");

【查看\設置屬性節(jié)點】

1、 查看屬性節(jié)點:.getAttribute("屬性名");

2、 設置屬性節(jié)點:.setAttribute("屬性名","屬性值");

注意事項:.setAttribute() 在老版本IE中會存在兼容性問題,可以使用.符號代替。

【JS修改CSS的多種方式】

1、 使用setAttribute設置class和style。

document.getElementById("first").setAttribute("class","class1");
document.getElementById("first").setAttribute("style","color:red;");

2、使用.className添加一個class選擇器。

document.getElementById("first").className = "class1";

3、 使用.style.樣式 直接修改單個樣式。 注意樣式名必須使用駝峰命名法。

document.getElementById("first").style.fontSize = "18px";

4、 使用.style 或 .style.cssText 添加一串行級樣式:

// IE不兼容
document.getElementById("first").style = "color:red;"; 
//所有瀏覽器兼容
document.getElementById("first").style.cssText = "color:red;";

【查看/設置文本節(jié)點】

1、.innerHTML: 取到或設置一個節(jié)點中的HTML代碼。

2、.innerText: 取到或設置一個節(jié)點中的文本,不能設置HTML代碼。

二、層次節(jié)點操作

1. .childNodes: 獲取當前節(jié)點的所有子節(jié)點(包括元素節(jié)點和文本節(jié)點)。

.children: 獲取當前節(jié)點的所有元素子節(jié)點(不包含文本節(jié)點)。

2. .parentNode: 獲取當前節(jié)點的父節(jié)點。

3. .firstChild: 獲取第一個子節(jié)點,包括回車等文本節(jié)點;

.firstElementChild: 獲取第一個元素節(jié)點。 不含文本節(jié)點;

.lastChild: 獲取最后一個子節(jié)點,包括回車等文本節(jié)點;

.lastElementChild: 獲取最后一個子節(jié)點,不含文本節(jié)點;

4. .previousSibling: 獲取當前節(jié)點的前一個兄弟節(jié)點,包括文本節(jié)點;

.previousElementSibling: 獲取當前節(jié)點的前一個元素兄弟節(jié)點;

.nextSibling:獲取當前節(jié)點的后一個兄弟節(jié)點,包括文本節(jié)點;

.nextElementSibling:獲取當前節(jié)點的后一個元素兄弟節(jié)點;

5. .attributes: 獲取當前節(jié)點的所有屬性節(jié)點。 返回數(shù)組格式。

【創(chuàng)建并新增節(jié)點】

1. document.createElement("標簽名"): 創(chuàng)建一個新節(jié)點,并將創(chuàng)建的新節(jié)點返回。

需要配合.setAttribute()為新節(jié)點設置屬性。

2. 父節(jié)點.insertBefore(新節(jié)點,目標節(jié)點): 在父節(jié)點中,將新節(jié)點插入到目標節(jié)點之前。

父節(jié)點.appendChild(新節(jié)點): 在父節(jié)點的內(nèi)部最后,插入一個新節(jié)點。

3. 源節(jié)點.cloneNode(true): 克隆一個節(jié)點。

傳入true表示克隆源節(jié)點以及源節(jié)點的所有子節(jié)點;

傳入false或不傳,表示只克隆當前節(jié)點,而不克隆子節(jié)點。

【刪除、替換節(jié)點】

1. 父節(jié)點.removeChild(子節(jié)點): 從父節(jié)點中,刪除指定子節(jié)點。

2. 父節(jié)點.replaceChild(新節(jié)點,老節(jié)點): 從父節(jié)點中,用新節(jié)點替換老節(jié)點。

相關文章

最新評論