JavaScript之DOM插入更新刪除_動力節(jié)點(diǎn)Java學(xué)院整理
JavaScript之DOM插入更新刪除,供大家參考,具體內(nèi)容如下
更新
拿到一個DOM節(jié)點(diǎn)后,我們可以對它進(jìn)行更新。
可以直接修改節(jié)點(diǎn)的文本,方法有兩種:
一種是修改innerHTML屬性,這個方式非常強(qiáng)大,不但可以修改一個DOM節(jié)點(diǎn)的文本內(nèi)容,還可以直接通過HTML片段修改DOM節(jié)點(diǎn)內(nèi)部的子樹:
// 獲取<p id="p-id">...</p>
var p = document.getElementById('p-id');
// 設(shè)置文本為abc:
p.innerHTML = 'ABC'; // <p id="p-id">ABC</p>
// 設(shè)置HTML:
p.innerHTML = 'ABC <span style="color:red">RED</span> XYZ';
// <p>...</p>的內(nèi)部結(jié)構(gòu)已修改
用innerHTML時要注意,是否需要寫入HTML。如果寫入的字符串是通過網(wǎng)絡(luò)拿到了,要注意對字符編碼來避免XSS攻擊。
第二種是修改innerText或textContent屬性,這樣可以自動對字符串進(jìn)行HTML編碼,保證無法設(shè)置任何HTML標(biāo)簽:
// 獲取<p id="p-id">...</p>
var p = document.getElementById('p-id');
// 設(shè)置文本:
p.innerText = '<script>alert("Hi")</script>';
// HTML被自動編碼,無法設(shè)置一個<script>節(jié)點(diǎn):
// <p id="p-id"><script>alert("Hi")</script></p>
兩者的區(qū)別在于讀取屬性時,innerText不返回隱藏元素的文本,而textContent返回所有文本。另外注意IE<9不支持textContent。
修改CSS也是經(jīng)常需要的操作。DOM節(jié)點(diǎn)的style屬性對應(yīng)所有的CSS,可以直接獲取或設(shè)置。因?yàn)镃SS允許font-size這樣的名稱,但它并非JavaScript有效的屬性名,所以需要在JavaScript中改寫為駝峰式命名fontSize:
// 獲取<p id="p-id">...</p>
var p = document.getElementById('p-id');
// 設(shè)置CSS:
p.style.color = '#ff0000';
p.style.fontSize = '20px';
p.style.paddingTop = '2em';
插入
當(dāng)我們獲得了某個DOM節(jié)點(diǎn),想在這個DOM節(jié)點(diǎn)內(nèi)插入新的DOM,應(yīng)該如何做?
如果這個DOM節(jié)點(diǎn)是空的,例如,<div></div>,那么,直接使用innerHTML = '<span>child</span>'就可以修改DOM節(jié)點(diǎn)的內(nèi)容,相當(dāng)于“插入”了新的DOM節(jié)點(diǎn)。
如果這個DOM節(jié)點(diǎn)不是空的,那就不能這么做,因?yàn)?span style="color: #800000">innerHTML會直接替換掉原來的所有子節(jié)點(diǎn)。
有兩個辦法可以插入新的節(jié)點(diǎn)。一個是使用appendChild,把一個子節(jié)點(diǎn)添加到父節(jié)點(diǎn)的最后一個子節(jié)點(diǎn)。例如:
<!-- HTML結(jié)構(gòu) --> <p id="js">JavaScript</p> <div id="list"> <p id="java">Java</p> <p id="python">Python</p> <p id="scheme">Scheme</p> </div>
把<p id="js">JavaScript</p>添加到<div id="list">的最后一項(xiàng):
var
js = document.getElementById('js'),
list = document.getElementById('list');
list.appendChild(js);
現(xiàn)在,HTML結(jié)構(gòu)變成了這樣:
<!-- HTML結(jié)構(gòu) --> <div id="list"> <p id="java">Java</p> <p id="python">Python</p> <p id="scheme">Scheme</p> <p id="js">JavaScript</p> </div>
因?yàn)槲覀儾迦氲膉s節(jié)點(diǎn)已經(jīng)存在于當(dāng)前的文檔樹,因此這個節(jié)點(diǎn)首先會從原先的位置刪除,再插入到新的位置。
更多的時候我們會從零創(chuàng)建一個新的節(jié)點(diǎn),然后插入到指定位置:
var
list = document.getElementById('list'),
haskell = document.createElement('p');
haskell.id = 'haskell';
haskell.innerText = 'Haskell';
list.appendChild(haskell);
這樣我們就動態(tài)添加了一個新的節(jié)點(diǎn):
<!-- HTML結(jié)構(gòu) --> <div id="list"> <p id="java">Java</p> <p id="python">Python</p> <p id="scheme">Scheme</p> <p id="haskell">Haskell</p> </div>
動態(tài)創(chuàng)建一個節(jié)點(diǎn)然后添加到DOM樹中,可以實(shí)現(xiàn)很多功能。舉個例子,下面的代碼動態(tài)創(chuàng)建了一個<style>節(jié)點(diǎn),然后把它添加到<head>節(jié)點(diǎn)的末尾,這樣就動態(tài)地給文檔添加了新的CSS定義:
var d = document.createElement('style');
d.setAttribute('type', 'text/css');
d.innerHTML = 'p { color: red }';
document.getElementsByTagName('head')[0].appendChild(d);
可以在Chrome的控制臺執(zhí)行上述代碼,觀察頁面樣式的變化。
insertBefore
如果我們要把子節(jié)點(diǎn)插入到指定的位置怎么辦?可以使用parentElement.insertBefore(newElement, referenceElement);,子節(jié)點(diǎn)會插入到referenceElement之前。
還是以上面的HTML為例,假定我們要把Haskell插入到Python之前:
<!-- HTML結(jié)構(gòu) --> <div id="list"> <p id="java">Java</p> <p id="python">Python</p> <p id="scheme">Scheme</p> </div>
可以這么寫:
var
list = document.getElementById('list'),
ref = document.getElementById('python'),
haskell = document.createElement('p');
haskell.id = 'haskell';
haskell.innerText = 'Haskell';
list.insertBefore(haskell, ref);
新的HTML結(jié)構(gòu)如下:
<!-- HTML結(jié)構(gòu) --> <div id="list"> <p id="java">Java</p> <p id="haskell">Haskell</p> <p id="python">Python</p> <p id="scheme">Scheme</p> </div>
可見,使用insertBefore重點(diǎn)是要拿到一個“參考子節(jié)點(diǎn)”的引用。很多時候,需要循環(huán)一個父節(jié)點(diǎn)的所有子節(jié)點(diǎn),可以通過迭代children屬性實(shí)現(xiàn):
var
i, c,
list = document.getElementById('list');
for (i = 0; i < list.children.length; i++) {
c = list.children[i]; // 拿到第i個子節(jié)點(diǎn)
}
刪除
刪除一個DOM節(jié)點(diǎn)就比插入要容易得多。
要刪除一個節(jié)點(diǎn),首先要獲得該節(jié)點(diǎn)本身以及它的父節(jié)點(diǎn),然后,調(diào)用父節(jié)點(diǎn)的removeChild把自己刪掉:
// 拿到待刪除節(jié)點(diǎn):
var self = document.getElementById('to-be-removed');
// 拿到父節(jié)點(diǎn):
var parent = self.parentElement;
// 刪除:
var removed = parent.removeChild(self);
removed === self; // true
注意到刪除后的節(jié)點(diǎn)雖然不在文檔樹中了,但其實(shí)它還在內(nèi)存中,可以隨時再次被添加到別的位置。
當(dāng)你遍歷一個父節(jié)點(diǎn)的子節(jié)點(diǎn)并進(jìn)行刪除操作時,要注意,children屬性是一個只讀屬性,并且它在子節(jié)點(diǎn)變化時會實(shí)時更新。
例如,對于如下HTML結(jié)構(gòu):
<div id="parent"> <p>First</p> <p>Second</p> </div>
當(dāng)我們用如下代碼刪除子節(jié)點(diǎn)時:
var parent = document.getElementById('parent');
parent.removeChild(parent.children[0]);
parent.removeChild(parent.children[1]); // <-- 瀏覽器報錯
瀏覽器報錯:parent.children[1]不是一個有效的節(jié)點(diǎn)。原因就在于,當(dāng)<p>First</p>節(jié)點(diǎn)被刪除后,parent.children的節(jié)點(diǎn)數(shù)量已經(jīng)從2變?yōu)榱?,索引[1]已經(jīng)不存在了。
因此,刪除多個節(jié)點(diǎn)時,要注意children屬性時刻都在變化。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js操作DOM--添加、刪除節(jié)點(diǎn)的簡單實(shí)例
- JavaScript中對DOM節(jié)點(diǎn)的訪問、創(chuàng)建、修改、刪除
- JavaScript DOM節(jié)點(diǎn)操作實(shí)例小結(jié)(新建,刪除HTML元素)
- JavaScript 高級篇之DOM文檔,簡單封裝及調(diào)用、動態(tài)添加、刪除樣式(六)
- javascript 刪除dom對象的事件函數(shù)代碼
- javascript DOM操作之動態(tài)刪除TABLE多行
- JS實(shí)現(xiàn)的DOM插入節(jié)點(diǎn)操作示例
- JS遍歷DOM文檔樹的方法實(shí)例詳解
- js中DOM事件綁定分析
- javascript 獲取HTML DOM父、子、臨近節(jié)點(diǎn)
- 詳解JS獲取HTML DOM元素的8種方法
- JS實(shí)現(xiàn)DOM刪除節(jié)點(diǎn)操作示例
相關(guān)文章
js網(wǎng)頁中隨意拖動的小方塊實(shí)現(xiàn)代碼
用CSS和JS制作的在網(wǎng)頁中可以隨意拖動的小方塊。2008-08-08
關(guān)于捕獲用戶何時點(diǎn)擊window.onbeforeunload的取消事件
關(guān)于捕獲用戶何時點(diǎn)擊window.onbeforeunload的取消事件的代碼,需要的朋友可以參考下。2011-03-03
wap手機(jī)圖片滑動切換特效無css3元素js腳本編寫
手機(jī)圖片滑動切換,網(wǎng)上有很多這樣的例子,但都借助于其他組件,讓代碼混亂的不行,本例無css3元素js腳本編寫,需要的朋友可以參考下2014-07-07
十個開發(fā)人員面臨的最常見的JavaScript問題總結(jié)
今天,JavaScript?是幾乎所有現(xiàn)代?Web?應(yīng)用的核心。這就是為什么JavaScript問題,以及找到導(dǎo)致這些問題的錯誤,是?Web?發(fā)者的首要任務(wù)。本文總結(jié)了十個常見的問題及解決方法,需要的可以參考一下2022-11-11
javascript簡化代碼 A=alert w=document.writeln
建議不要這樣寫代碼,考慮以后的修改才是最重要的,代碼分層.多把一個功能寫成一個js代碼或一個類,然后提供接口,這種寫法代碼會更多,速度也更慢,但人人都推薦這樣寫,是因?yàn)檫@樣子維護(hù)方便.而程序不可能一次性寫得完美的,永遠(yuǎn)都可以改進(jìn)2008-02-02
Javascript BOM學(xué)習(xí)小結(jié)(六)
BOM:BrowserObjectModel,瀏覽器對象模型,提供JS中對瀏覽器的各種操作的對象,是JS應(yīng)用中唯一沒有相關(guān)標(biāo)準(zhǔn)的部分,這事BOM經(jīng)常出現(xiàn)問題的所在,主要用于處理瀏覽器窗口與框架,瀏覽器特有的JS擴(kuò)展也被默認(rèn)為BOM的一部分,而各瀏覽器之間的公有對象就成了默認(rèn)的標(biāo)準(zhǔn)2015-11-11
es7學(xué)習(xí)教程之Decorators(修飾器)詳解
這篇文章主要給大家介紹了關(guān)于es7中Decorators(修飾器)的相關(guān)資料,文中通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)吧。2017-07-07

