今天學習了原生js的dom節點的操做,就記錄下來,僅供本身之後參考。html
1)建立節點:除了可使用createElement建立元素,也可使用createTextNode建立文本節點.chrome
document.body指向的是<body>元素;document.documentElement則指向<html>元素瀏覽器
// 建立節點 app
vardom
createNode = document.createElement("div");性能
var學習
createTextNode = document.createTextNode("hello world");優化
createNode.appendChild(createTextNode);htm
document.body.appendChild(createNode);seo
document.documentElement.appendChild(createNode);
2)插入節點:可使用appendChild,insertBefore,insertBefore接收兩個參數,第一個是插入的節點,第二個是參照節點,如insertBefore(a,b),則a會插入在b的前面
// 插入節點
var
createNode = document.createElement("div");
var
createTextNode = document.createTextNode("hello world");
createNode.appendChild(createTextNode);
var
div1 = document.getElementById("div1");
document.body.insertBefore(createNode,div1);
3)替換和刪除元素,從replaceChild和removeChild的字面意思看,就是刪除子節點,所以調用者,須要包含子節點div1,否則調用會報錯。返回的節點是替換的或刪除的元素,被替換/刪除的元素仍然存在,但document中已經沒有他們的位置了。
// 替換元素
var replaceChild = document.body.replaceChild(createNode,div1);
// 刪除元素
var removeChild = document.body.removeChild(div1);
4)節點的屬性:
firstChild:第一個子節點
lastChild:最後一個子節點
childNodes:子節點集合,獲取其中子節點能夠someNode.childNodes[index]或者someNode.childNodes.item(index)
nextSibling:下一個兄弟節點
previousSibling:上一個兄弟節點
parentNode:父節點
< ul id ="ul" >< li > sdsssssss </ li >< li > qqqq </ li >< li > wwww </ li >< li > eeee </ li></ ul >
// 節點屬性
var
ul = document.getElementById("ul");
var
firstChild = ul.firstChild;
console.log(firstChild.innerHTML);
var
lastChild = ul.lastChild;
console.log(lastChild.innerHTML);
var
length = ul.childNodes.length;
console.log(length);
var
secondChild = ul.childNodes.item(1);
console.log(secondChild.innerHTML);
var
forthChild = ul.childNodes.item(2).nextSibling;
console.log(forthChild.innerHTML);
var
thridChild = forthChild.previousSibling;
console.log(thridChild.innerHTML);
var
parentNode = forthChild.parentNode;
console.log(parentNode.innerHTML);
5) 文檔片斷,好處在於減小dom的渲染次數,能夠優化性能。
// 文本片斷
var
fragment = document.createDocumentFragment();
var
ul = document.getElementById("ul");
var li =
null
;
for (
var
i = 4; i >= 0; i--) {
li = document.createElement("li");
li.appendChild(document.createTextNode("item "+i));
fragment.appendChild(li);
}
ul.appendChild(fragment);
6)克隆元素
someNode.cloneNode(true):深度克隆,會複製節點及整個子節點
someNode.cloneNode(false):淺克隆,會複製節點,但不復制子節點
// 克隆
var clone = ul.cloneNode(
true
);
document.body.appendChild(clone);
一、childNodes.length存在跨瀏覽器的問題
能夠看到有關列表的html片斷沒有用
< ul id ="ul"
>
< li > sdsssssss </ li
>
< li > qqqq </ li
>
< li > wwww </ li
>
< li > eeee </ li
>
</ ul
>
這種書寫格式而是使用沒有換行的格式書寫,是由於在不一樣的瀏覽器中,獲取ul.childNodes.length的結果有差別:
在ie中,ul.childNodes.length不會計算li之間的換行空格,從而獲得數值爲4
在ff、chrome,safari中,會有包含li之間的空白符的5個文本節點,所以ul.childNodes.length爲9
若要解決跨瀏覽器問題,能夠將li之間的換行去掉,改爲一行書寫格式。
二、cloneNode存在跨瀏覽器的問題
在IE中,經過cloneNode方法複製的元素,會複製事件處理程序,好比,var b = a.cloneNode(true).若a存在click,mouseover等事件監聽,則b也會擁有這些事件監聽。
在ff,chrome,safari中,經過cloneNode方法複製的元素,只會複製特性,其餘一切都不會複製
所以,若要解決跨瀏覽器問題,在複製前,最好先移除事件處理程序。