javascript學(xué)習(xí)筆記(十九) 節(jié)點的操作實現(xiàn)代碼
更新時間:2012年06月20日 20:28:53 作者:
javascript學(xué)習(xí)筆記之節(jié)點的操作實現(xiàn)代碼,包括節(jié)點的創(chuàng)建、添加、移除、替換、復(fù)制
本節(jié)要用到的html例子
<ul id="myList">
<li>項目一</li>
<li>項目二</li>
<li>項目三</li>
</ul>
1.創(chuàng)建元素節(jié)點
document.createElement() 方法 用于創(chuàng)建元素,接受一個參數(shù),即要創(chuàng)建元素的標簽名,返回創(chuàng)建的元素節(jié)點
var div = document.createElement("div"); //創(chuàng)建一個div元素
div.id = "myDiv"; //設(shè)置div的id
div.className = "box"; //設(shè)置div的class
創(chuàng)建元素后還要把元素添加到文檔樹中
2.添加元素節(jié)點
appendChild() 方法 用于向childNodes列表的末尾添加一個節(jié)點,返回要添加的元素節(jié)點
var ul = document.getElementById("myList"); //獲得ul
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML = "項目四"; //向li內(nèi)添加文本
ul.appendChild(li); //把li 添加到ul子節(jié)點的末尾
添加后:
<ul id="myList">
<li>項目一</li>
<li>項目二</li>
<li>項目三</li>
<li>項目四</li>
</ul>
appendChild() 方法還可以添加已經(jīng)存在的元素,會將元素從原來的位置移到新的位置
var ul = document.getElementById("myList"); //獲得ul
ul.appendChild(ul.firstChild); //把ul的第一個元素節(jié)點移到ul子節(jié)點的末尾
運行后(IE):
<ul id="myList">
<li>項目二</li>
<li>項目三</li>
<li>項目一</li>
</ul>
insertBefore() 方法 ,如果不是在末尾插入節(jié)點,而是想放在特定的位置上,用這個方法,該方法接受2個參數(shù),第一個是要插入的節(jié)點,第二個是參照節(jié)點,返回要添加的元素節(jié)點
var ul = document.getElementById("myList"); //獲得ul
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML= "項目四"; //向li內(nèi)添加文本
ul.insertBefore(li,ul.firstChild); //把li添加到ul的第一個子節(jié)點前
添加后:
<ul id="myList">
<li>項目四</li>
<li>項目一</li>
<li>項目二</li>
<li>項目三</li>
</ul>
var ul = document.getElementById("myList"); //獲得ul
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML= "項目四"; //向li內(nèi)添加文本
ul.insertBefore(li,ul.null); //把li添加到ul的子節(jié)點末尾
添加后:
<ul id="myList">
<li>項目一</li>
<li>項目二</li>
<li>項目三</li>
<li>項目四</li>
</ul>
var ul = document.getElementById("myList"); //獲得ul
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML= "項目四"; //向li內(nèi)添加文本
var lis = ul.getElementsByTagName("li") //獲取ul中所有l(wèi)i的集合
ul.insertBefore(li,lis[1]); //把li添加到ul中的第二個li節(jié)點前
添加后:
<ul id="myList">
<li>項目一</li>
<li>項目四</li>
<li>項目二</li>
<li>項目三</li>
</ul>
3.移除元素節(jié)點
removeChild() 方法 ,用于移除節(jié)點,接受一個參數(shù),即要移除的節(jié)點,返回被移除的節(jié)點,注意被移除的節(jié)點仍然在文檔中,不過文檔中已沒有其位置了
var ul = document.getElementById("myList"); //獲得ul
var fromFirstChild = ul.removeChild(ul.firstChild); //移除ul第一個子節(jié)點1 var ul = document.getElementById("myList"); //獲得ul
var lis = ul.getElementsByTagName("li") //獲取ul中所有l(wèi)i的集合
ul.removeChild(lis[0]); //移除第一個li,與上面不同,要考慮瀏覽器之間的差異
4.替換元素節(jié)點
replaceChild() 方法 ,用于替換節(jié)點,接受兩個參數(shù),第一參數(shù)是要插入的節(jié)點,第二個是要替換的節(jié)點,返回被替換的節(jié)點
var ul = document.getElementById("myList"); //獲得ul
var fromFirstChild = ul.replaceChild(ul.firstChild); //替換ul第一個子節(jié)點1 var ul = document.getElementById("myList"); //獲得ul;
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML= "項目四"; //向li內(nèi)添加文本
var lis = ul.getElementsByTagName("li") //獲取ul中所有l(wèi)i的集合
var returnNode = ul.replaceChild(li,lis[1]); //用創(chuàng)建的li替換原來的第二個li
5.復(fù)制節(jié)點
cloneNode() 方法,用于復(fù)制節(jié)點, 接受一個布爾值參數(shù), true 表示深復(fù)制(復(fù)制節(jié)點及其所有子節(jié)點), false 表示淺復(fù)制(復(fù)制節(jié)點本身,不復(fù)制子節(jié)點)
var ul = document.getElementById("myList"); //獲得ul
var deepList = ul.cloneNode(true); //深復(fù)制
var shallowList = ul.cloneNode(false); //淺復(fù)制
節(jié)點的操作要注意IE和其它瀏覽器的差異(第十八節(jié)中有講到)
復(fù)制代碼 代碼如下:
<ul id="myList">
<li>項目一</li>
<li>項目二</li>
<li>項目三</li>
</ul>
1.創(chuàng)建元素節(jié)點
document.createElement() 方法 用于創(chuàng)建元素,接受一個參數(shù),即要創(chuàng)建元素的標簽名,返回創(chuàng)建的元素節(jié)點
復(fù)制代碼 代碼如下:
var div = document.createElement("div"); //創(chuàng)建一個div元素
div.id = "myDiv"; //設(shè)置div的id
div.className = "box"; //設(shè)置div的class
創(chuàng)建元素后還要把元素添加到文檔樹中
2.添加元素節(jié)點
appendChild() 方法 用于向childNodes列表的末尾添加一個節(jié)點,返回要添加的元素節(jié)點
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList"); //獲得ul
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML = "項目四"; //向li內(nèi)添加文本
ul.appendChild(li); //把li 添加到ul子節(jié)點的末尾
添加后:
復(fù)制代碼 代碼如下:
<ul id="myList">
<li>項目一</li>
<li>項目二</li>
<li>項目三</li>
<li>項目四</li>
</ul>
appendChild() 方法還可以添加已經(jīng)存在的元素,會將元素從原來的位置移到新的位置
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList"); //獲得ul
ul.appendChild(ul.firstChild); //把ul的第一個元素節(jié)點移到ul子節(jié)點的末尾
運行后(IE):
復(fù)制代碼 代碼如下:
<ul id="myList">
<li>項目二</li>
<li>項目三</li>
<li>項目一</li>
</ul>
insertBefore() 方法 ,如果不是在末尾插入節(jié)點,而是想放在特定的位置上,用這個方法,該方法接受2個參數(shù),第一個是要插入的節(jié)點,第二個是參照節(jié)點,返回要添加的元素節(jié)點
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList"); //獲得ul
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML= "項目四"; //向li內(nèi)添加文本
ul.insertBefore(li,ul.firstChild); //把li添加到ul的第一個子節(jié)點前
添加后:
復(fù)制代碼 代碼如下:
<ul id="myList">
<li>項目四</li>
<li>項目一</li>
<li>項目二</li>
<li>項目三</li>
</ul>
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList"); //獲得ul
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML= "項目四"; //向li內(nèi)添加文本
ul.insertBefore(li,ul.null); //把li添加到ul的子節(jié)點末尾
添加后:
復(fù)制代碼 代碼如下:
<ul id="myList">
<li>項目一</li>
<li>項目二</li>
<li>項目三</li>
<li>項目四</li>
</ul>
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList"); //獲得ul
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML= "項目四"; //向li內(nèi)添加文本
var lis = ul.getElementsByTagName("li") //獲取ul中所有l(wèi)i的集合
ul.insertBefore(li,lis[1]); //把li添加到ul中的第二個li節(jié)點前
添加后:
復(fù)制代碼 代碼如下:
<ul id="myList">
<li>項目一</li>
<li>項目四</li>
<li>項目二</li>
<li>項目三</li>
</ul>
3.移除元素節(jié)點
removeChild() 方法 ,用于移除節(jié)點,接受一個參數(shù),即要移除的節(jié)點,返回被移除的節(jié)點,注意被移除的節(jié)點仍然在文檔中,不過文檔中已沒有其位置了
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList"); //獲得ul
var fromFirstChild = ul.removeChild(ul.firstChild); //移除ul第一個子節(jié)點1 var ul = document.getElementById("myList"); //獲得ul
var lis = ul.getElementsByTagName("li") //獲取ul中所有l(wèi)i的集合
ul.removeChild(lis[0]); //移除第一個li,與上面不同,要考慮瀏覽器之間的差異
4.替換元素節(jié)點
replaceChild() 方法 ,用于替換節(jié)點,接受兩個參數(shù),第一參數(shù)是要插入的節(jié)點,第二個是要替換的節(jié)點,返回被替換的節(jié)點
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList"); //獲得ul
var fromFirstChild = ul.replaceChild(ul.firstChild); //替換ul第一個子節(jié)點1 var ul = document.getElementById("myList"); //獲得ul;
var li = document.createElement("li"); //創(chuàng)建li
li.innerHTML= "項目四"; //向li內(nèi)添加文本
var lis = ul.getElementsByTagName("li") //獲取ul中所有l(wèi)i的集合
var returnNode = ul.replaceChild(li,lis[1]); //用創(chuàng)建的li替換原來的第二個li
5.復(fù)制節(jié)點
cloneNode() 方法,用于復(fù)制節(jié)點, 接受一個布爾值參數(shù), true 表示深復(fù)制(復(fù)制節(jié)點及其所有子節(jié)點), false 表示淺復(fù)制(復(fù)制節(jié)點本身,不復(fù)制子節(jié)點)
復(fù)制代碼 代碼如下:
var ul = document.getElementById("myList"); //獲得ul
var deepList = ul.cloneNode(true); //深復(fù)制
var shallowList = ul.cloneNode(false); //淺復(fù)制
節(jié)點的操作要注意IE和其它瀏覽器的差異(第十八節(jié)中有講到)
您可能感興趣的文章:
- JavaScript DOM節(jié)點操作方法總結(jié)
- Javascript的各種節(jié)點操作實例演示代碼
- JavaScript 節(jié)點操作 以及DOMDocument屬性和方法
- js操作DOM--添加、刪除節(jié)點的簡單實例
- JavaScript操作HTML DOM節(jié)點的基礎(chǔ)教程
- JavaScript節(jié)點及列表操作實例小結(jié)
- Js操作樹節(jié)點自動折疊展開的幾種方法
- 使用js完成節(jié)點的增刪改復(fù)制等的操作
- js和jquery對dom節(jié)點的操作(創(chuàng)建/追加)
- javascript dom操作之cloneNode文本節(jié)點克隆使用技巧
- JavaScript原生節(jié)點操作小結(jié)
相關(guān)文章
一篇文章帶你搞懂JavaScript的變量與數(shù)據(jù)類型
這篇文章主要為大家介紹了JavaScript的變量與數(shù)據(jù)類型,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-01-01
javascript學(xué)習(xí)筆記(三) String 字符串類型介紹
javascript學(xué)習(xí)筆記之String 字符串類型介紹,這里介紹的是js字符串處理常用函數(shù)2012-06-06
THREE.JS入門教程(5)你應(yīng)當(dāng)知道的十件事
Three.js是一個偉大的開源WebGL庫,WebGL允許JavaScript操作GPU,在瀏覽器端實現(xiàn)真正意義的3D,本文會讓你了解一下使用THREE.JS處理3D/避免SetInterval/使用倒序循環(huán)等等,感興趣的朋友可以了解下哦2013-01-01
JavaScript操作數(shù)組的常用方法總結(jié)
這篇文章總結(jié)了JavaScript操作數(shù)組的常用方法,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06

