javascript創(chuàng)建元素和刪除元素實(shí)例小結(jié)
本文實(shí)例講述了javascript創(chuàng)建元素和刪除元素。分享給大家供大家參考,具體如下:
1、創(chuàng)建元素
動(dòng)態(tài)創(chuàng)建新的DOM元素,是js操作網(wǎng)頁(yè)對(duì)象模型的重要手段之一。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>www.dbjr.com.cn 創(chuàng)建新元素</title> <script type="text/javascript"> //創(chuàng)建新元素 function createNewElements(){ //使用innerHTML創(chuàng)建新元素 var p1 = document.getElementById("p1"); //設(shè)置innerHTML內(nèi)容 p1.innerHTML = "<span>我的dom文本1</span>"; //使用createElement來(lái)創(chuàng)建新元素 var span = document.createElement("span"); //為新元素內(nèi)容創(chuàng)建一個(gè)文本節(jié)點(diǎn) span.appendChild(document.createTextNode("我的dom文本2")); var p2 = document.getElementById("p2"); //掛接 p2.appendChild(span); } </script> </head> <body style="text-align:center"> <p> <input type="button" value="創(chuàng)建新元素" onclick="createNewElements()"/> </p> <!--定義為新元素掛接的容器元素--> <p id="p1"></p> <p id="p2"></p> </body> </html>
運(yùn)行效果:
創(chuàng)建新元素通常有2種方法:
1、直接修改父元素的innerHTML元素;
2、使用createElement()來(lái)創(chuàng)建,再用appendChild()進(jìn)行DOM元素的掛接。
第一種方法用起來(lái)較為簡(jiǎn)單,也易于理解,但需要修改整個(gè)父元素所包含的HTML內(nèi)容,若父元素原先就包含了一些HTML內(nèi)容,再進(jìn)行DOM掛接的話,執(zhí)行效率會(huì)較低;第二種方法相對(duì)較為靈活,效率也較高,只是用起來(lái)復(fù)雜一些。
2、刪除元素
刪除元素指的是把這個(gè)DOM元素徹底刪除,而不是隱藏。通常,使用removeChild()進(jìn)行刪除是最常見(jiàn)的方法。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>www.dbjr.com.cn 刪除元素</title> <script type="text/javascript"> //刪除元素 function deleteElement(){ //獲取準(zhǔn)備刪除的DOM var del = document.getElementById("del"); //調(diào)用刪除函數(shù)徹底刪除 del.parentNode.removeChild(del); } </script> </head> <body style="text-align:center"> <p> <input type="button" value="刪除元素" onclick="deleteElement()"/> </p> <!--定義被刪除的元素--> <span id="del">即將被刪除的DOM</span> </body> </html>
解析:
由于removeChild()是對(duì)子元素的操作,而不是自身的刪除。所以,需要先獲取待刪除元素的父元素,然后再調(diào)用該函數(shù)。本例中,是先使用parentNode屬性獲得待刪除元素的父元素,再刪除目標(biāo)元素。
3、刪除所有的子元素
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>刪除所有的子元素</title> <script type="text/javascript"> //刪除元素的函數(shù) function deleteChilds(){ //獲取父DOM var ul = document.getElementsByTagName('ul')[0]; //判斷是否包含子元素 if (ul.hasChildNodes()) { var len = ul.childNodes.length; //子元素的個(gè)數(shù) for (var i = 0; i < len; i++) { //遍歷 ul.removeChild(ul.childNodes[0]);//從第一個(gè)元素開(kāi)始刪除 } } } </script> </head> <body style="text-align:center"> <ul> <li>item1</li> <li>item2</li> <li>item3</li> <li>item4</li> </ul> </br> <input type="button" value="刪除所有的子元素" onclick="deleteChilds()" /> </body> </html>
解析:刪除子元素,可通過(guò)js提供的removeChild()
來(lái)實(shí)現(xiàn)。此外,需要意識(shí)到的另一點(diǎn)是,在遍歷刪除節(jié)點(diǎn)的過(guò)程中,每刪除一個(gè)子元素,子元素的個(gè)數(shù)就會(huì)少一個(gè),因此,示例代碼始終刪除的是第一個(gè)子元素,直到?jīng)]有任何子元素為止。
注:
document.getElementsByTagName(“ul”)
返回的是一個(gè)數(shù)組,后面這個(gè)0是表示這個(gè)數(shù)組的第一個(gè)元素,而本網(wǎng)頁(yè)中ul標(biāo)簽就一個(gè),因此指的就是這個(gè)ul標(biāo)簽了。
感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。
更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專(zhuān)題:《JavaScript操作DOM技巧總結(jié)》、《JavaScript頁(yè)面元素操作技巧總結(jié)》、《JavaScript事件相關(guān)操作與技巧大全》、《JavaScript查找算法技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》
希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。
- JS動(dòng)態(tài)創(chuàng)建元素的兩種方法
- js創(chuàng)建元素(節(jié)點(diǎn))示例
- JS中動(dòng)態(tài)創(chuàng)建元素的三種方法總結(jié)(推薦)
- 淺析JS動(dòng)態(tài)創(chuàng)建元素【兩種方法】
- JavaScript數(shù)組Array對(duì)象增加和刪除元素方法總結(jié)
- JS 添加刪除元素的實(shí)現(xiàn)代碼
- js中數(shù)組插入、刪除元素操作的方法
- javascript動(dòng)態(tài)創(chuàng)建及刪除元素的方法
- javascript刪除元素節(jié)點(diǎn)removeChild()用法實(shí)例
- JavaScript實(shí)現(xiàn)添加、查找、刪除元素
相關(guān)文章
用javascript實(shí)現(xiàn)始終保持打開(kāi)同一個(gè)子窗口以及關(guān)閉父窗口同時(shí)自動(dòng)關(guān)閉所有子窗口
用javascript實(shí)現(xiàn)始終保持打開(kāi)同一個(gè)子窗口以及關(guān)閉父窗口同時(shí)自動(dòng)關(guān)閉所有子窗口...2007-06-06JavaScript中Null與Undefined的區(qū)別解析
這篇文章主要介紹了JavaScript中Null與Undefined的區(qū)別解析,本文給出了多個(gè)代碼實(shí)例講解它們之間的區(qū)別,需要的朋友可以參考下2015-06-06js圖片上傳中file、bolb、base64圖片之間的相互轉(zhuǎn)化
這篇文章主要介紹了js圖片上傳中file、bolb、base64圖片之間的相互轉(zhuǎn)化,blob轉(zhuǎn)file,blob轉(zhuǎn)base64,base64轉(zhuǎn)file,使用canvas壓縮圖片,需要的朋友可以參考下2022-05-05javascript之IE版本檢測(cè)超簡(jiǎn)單方法
下面小編就為大家?guī)?lái)一篇javascript之IE版本檢測(cè)超簡(jiǎn)單方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-08-08Typescript中將字符串轉(zhuǎn)為數(shù)值的方法小結(jié)
在TypeScript中,將字符串轉(zhuǎn)換為數(shù)值(即字符串到數(shù)字的類(lèi)型轉(zhuǎn)換)有幾種方法,本文講給大家介紹幾種常見(jiàn)的方法,每個(gè)方法有對(duì)應(yīng)的代碼示例,需要的朋友可以參考下2023-08-08