1. 程式人生 > >js的DOM節點操作:創建 ,插入,刪除,復制,查找節點

js的DOM節點操作:創建 ,插入,刪除,復制,查找節點

con 函數 nts html屬性 追加 clas tracking nodes 末尾

DOM含義:DOM是文檔對象模型(Document Object Model,是基於瀏覽器編程的一套API接口,是W3C出臺的推薦標準。其賦予了JS操作節點的能力。當網頁被加載時,瀏覽器就會創建頁面的文檔對象模型。
節點:根據 W3C 的 HTML DOM 標準,HTML 文檔中的所有內容都是節點:
1、整個文檔時一個文檔節點。
2、每個HTML元素是元素節點。
3、HTML元素內的文本是文本節點。
4、每個HTML屬性是屬性節點。
5、每個註釋是註釋節點。
所以HTML DOM 將 HTML 文檔視作樹結構,這種結構被稱為節點樹。通過 HTML DOM,節點樹中的所有節點都可以通過 JS 進行訪問。所有 HTML 元素(節點)均可被修改。


一、創建節點、追加節點
1、createElement(標簽名)創建一個元素節點(具體的一個元素)。
2、appendChild(節點)追加一個節點。
3、createTextNode(節點文本內容)創建一個文本節點
[html]
view plain copy
[html] view plain copy
  1. var oDiv = document.createElement("div");//創建一個div元素,因為是document對象的方法。
  2. var oDivText = document.createTextNode("666");//創建一個文本節點內容是“666”,因為是document對象的方法。
  3. oDiv.appendChild(oDivText);//父級.appendChild(子節點);在div元素中添加“666”
  4. document.body.appendChild(oDiv);//父級.appendChild(子節點);;document.body是指向<body>元素
  5. document.documentElement.appendChild(createNode);//父級.appendChild(子節點);;document.documentElement是指向<html>元素
二、插入節點
1、appendChild(節點)也是一種插入節點的方式,還可以添加已經存在的元素,會將其元素從原來的位置移到新的位置。
2、insertBefore(a,b)是參照節點,意思是a節點會插入b節點的前面。
[html] view plain copy
  1. var oDiv = document.createElement("div");//創建一個div元素,因為是document對象的方法。
  2. var oDiv1 = document.getElementById("div1");
  3. document.body.insertBefore(oDiv,oDiv1);//在oDiv1節點前插入新創建的元素節點
  4. ul.appendChild(ul.firstChild); //把ul的第一個元素節點移到ul子節點的末尾
三、刪除、移除節點
1、removeChild(節點) 刪除一個節點,用於移除刪除一個參數(節點)。其返回的被移除的節點,被移除的節點仍在文檔中,只是文檔中已沒有其位置了。
[html] view plain copy
  1. var removeChild = document.body.removeChild(div1);//移除document對象的方法div1
四、替換節點
1、replaceChild(插入的節點,被替換的節點) ,用於替換節點,接受兩個參數,第一參數是要插入的節點,第二個是要被替換的節點。返回的是被替換的節點。
[html] view plain copy
  1. var replaceChild= document.body.replaceChild(div1,div2); //將div1替換div2
五、查找節點
1、childNodes 包含文本節點和元素節點的子節點。
[html] view plain copy
  1. for (var i = 0; i < oList.childNodes.length; i++) {//oList是做的ul的對象。
  2. //nodeType是節點的類型,利用nodeType來判斷節點類型,再去控制子節點
  3. //nodeType==1 是元素節點
  4. //nodeType==3 是文本節點
  5. if (oList.childNodes[i].nodeType == 1) {//查找到oList內的元素節點
  6. console.log(oList.childNodes[i]);//在控制器日誌中顯示找到的元素節點
  7. }
  8. }
2、A、children也可以獲取子節點,而且兼容各種瀏覽器。包括IE6-8
B、parentNode:獲取父節點
[html] view plain copy
  1. var oList = document.getElementById(‘list‘);//oList是做的ul的對象
  2. var oChild=document.getElementById(‘child‘);//oChild是做的ul中的一個li的對象
  3. //通過子節點查找父節點//parentNode:獲取父節點
  4. console.log(oChild.parentNode);//在控制器日誌中顯示父節點
  5. console.log(oList.children);//在控制器日誌中顯示oList子節點
  6. console.log(children.length)//子節點的個數
3、A、firstChild ; firstElementChild查找第一個子節點。此存在瀏覽器兼容問題:firstChild是IE兼容,firstElementChild是非IE兼容。

[html] view plain copy
  1. <span style="white-space:pre;"> </span>//查找第一個子節點的封裝函數
  2. <span style="white-space:pre;"> </span>function firstChild(ele) {
  3. <span style="white-space:pre;"> </span>if (ele.firstElementChild) {<span style="font-family:Arial, Helvetica, sans-serif;">//如果該條件是true則在該瀏覽器(IE或非IE)中兼容</span>
  4. <span style="white-space:pre;"> </span> return ele.firstElementChild;
  5. <span style="white-space:pre;"> </span>} else {
  6. <span style="white-space:pre;"> </span> return ele.firstChild;
  7. <span style="white-space:pre;"> </span>}
  8. <span style="white-space:pre;"> </span>}
  9. <span style="white-space:pre;"> </span>firstChild(oList).style.background = ‘red‘;//將獲得的節點的背景變成紅色
B、lastChild ; lastElementChild查找最後一個子節點。此存在瀏覽器兼容問題:lastChild 是IE兼容,lastElementChild是非IE兼容。

[html] view plain copy
  1. <span style="white-space:pre;"> </span>//查找最後一個子節點的封裝函數
  2. <span style="white-space:pre;"> </span>function lastChild(ele) {
  3. <span style="white-space:pre;"> </span>if (ele.lastElementChild) {<span style="font-family:Arial, Helvetica, sans-serif;">//如果該條件是true則在該瀏覽器(IE或非IE)中兼容</span>
  4. <span style="white-space:pre;"> </span> return ele.lastElementChild;
  5. <span style="white-space:pre;"> </span>} else {
  6. <span style="white-space:pre;"> </span> return ele.lastChild;
  7. <span style="white-space:pre;"> </span>}
  8. <span style="white-space:pre;"> </span>}
  9. <span style="white-space:pre;"> </span>lastChild(oList).style.background = ‘red‘;//將獲得的節點的背景變成紅色
C、nextSibling ; nextElementSibling查找下一個兄弟節點。也是存在兼容性問題。
[html] view plain copy
  1. <span style="white-space:pre;"> </span>//查找下一個兄弟節點的封裝函數
  2. <span style="white-space:pre;"> </span>function nextSibling(ele) {
  3. <span style="white-space:pre;"> </span>if (ele.nextElementSibling) {
  4. <span style="white-space:pre;"> </span> return ele.nextElementSibling;
  5. <span style="white-space:pre;"> </span>} else {
  6. <span style="white-space:pre;"> </span> return ele.nextSibling;
  7. <span style="white-space:pre;"> </span>}
  8. <span style="white-space:pre;"> </span>}
  9. <span style="white-space:pre;"> </span>nextSibling(oMid).style.background = ‘red‘;

D、previousSibling ; previousElementSibling查找上一個兄弟節點。也是存在兼容性問題。

[html] view plain copy
  1. <span style="white-space:pre;"> </span>//查找上一個兄弟節點的封裝函數
  2. <span style="white-space:pre;"> </span>function previousSibling(ele) {
  3. <span style="white-space:pre;"> </span>if (ele.nextElementSibling) {
  4. <span style="white-space:pre;"> </span> return ele.previousElementSibling;
  5. <span style="white-space:pre;"> </span>} else {
  6. <span style="white-space:pre;"> </span> return ele.previousSibling;
  7. <span style="white-space:pre;"> </span> }
  8. <span style="white-space:pre;"> </span>}
  9. <span style="white-space:pre;"> </span>previousSibling(oMid).style.background = ‘red‘;

js的DOM節點操作:創建 ,插入,刪除,復制,查找節點