基于DOM節(jié)點(diǎn)刪除之empty和remove的區(qū)別(詳解)
要移除頁面上節(jié)點(diǎn)是開發(fā)者常見的操作,jQuery提供了幾種不同的方法用來處理這個問題,這里我們開仔細(xì)了解下empty和remove方法
empty 顧名思義,清空方法,但是與刪除又有點(diǎn)不一樣,因?yàn)樗灰瞥?指定元素中的所有子節(jié)點(diǎn)。
這個方法不僅移除子元素(和其他后代元素),同樣移除元素里的文本。因?yàn)椋鶕?jù)說明,元素里任何文本字符串都被看做是該元素的子節(jié)點(diǎn)。請看下面的HTML:
<div class="hello"><p>這是p標(biāo)簽</p></div>
如果我們通過empty方法移除里面div的所有元素,它只是清空內(nèi)部的html代碼,但是標(biāo)記仍然留在DOM中
//通過empty處理
$('.hello').empty()
//結(jié)果:<p>這是p標(biāo)簽</p>被移除
<div class="hello"></div>
通過empty移除了當(dāng)前div元素下的所有p元素,但是本身id=test的div元素沒有被刪除
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
<title></title>
<script src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script>
<style>
div {
background: #bbffaa;
width: 300px;
}
</style>
</head>
<body>
<h2>通過empty移除元素</h2>
<div id="test">
<p>p元素1</p>
<p>p元素2</p>
</div>
<button>點(diǎn)擊通過jQuery的empty移除元素</button>
<script type="text/javascript">
$("button").on('click', function() {
//通過empty移除了當(dāng)前div元素下的所有p元素
//但是本身id=test的div元素沒有被刪除
$("#test").empty()
})
</script>
</body>
</html>
remove與empty一樣,都是移除元素的方法,但是remove會將元素自身移除,同時也會移除元素內(nèi)部的一切,包括綁定的事件及與該元素相關(guān)的jQuery數(shù)據(jù)。
例如一段節(jié)點(diǎn),綁定點(diǎn)擊事件
<div class="hello"><p>這是P段落</p></div>
$('.hello').on("click",fn)
如果不通過remove方法刪除這個節(jié)點(diǎn)其實(shí)也很簡單,但是同時需要把事件給銷毀掉,這里是為了防止"內(nèi)存泄漏",所以前端開發(fā)者一定要注意,綁了多少事件,不用的時候一定要記得銷毀
通過remove方法移除div及其內(nèi)部所有元素,remove內(nèi)部會自動操作事件銷毀方法,所以使用使用起來非常簡單
//通過remove處理
$('.hello').remove()
//結(jié)果:<div class="hello"><p>這是P段落</p></div> 全部被移除 //節(jié)點(diǎn)不存在了,同事事件也會被銷毀
remove表達(dá)式參數(shù):
remove比empty好用的地方就是可以傳遞一個選擇器表達(dá)式用來過濾將被移除的匹配元素集合,可以選擇性的刪除指定的節(jié)點(diǎn)
我們可以通過$()選擇一組相同的元素,然后通過remove()傳遞篩選的規(guī)則,從而這樣處理
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
<title></title>
<script src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script>
<style>
.test1 {
background: #bbffaa;
}
.test2 {
background: yellow;
}
</style>
</head>
<body>
<h2>通過jQuery remove方法移除元素</h2>
<div class="test1">
<p>p元素1</p>
<p>p元素2</p>
</div>
<div class="test2">
<p>p元素3</p>
<p>p元素4</p>
</div>
<button>通過點(diǎn)擊jQuery的empty移除元素</button>
<button>通過點(diǎn)擊jQuery的empty移除指定元素</button>
<script type="text/javascript">
$("button:first").on('click', function() {
//刪除整個 class=test1的div節(jié)點(diǎn)
$(".test1").remove()
})
$("button:last").on('click', function() {
//找到所有p元素中,包含了3的元素
//這個也是一個過濾器的處理
$("p").remove(":contains('3')")
})
</script>
</body>
</html>
要用到移除指定元素的時候,jQuery提供了empty()與remove([expr])二個方法,兩個都是刪除元素,但是兩者還是有區(qū)別:
要用到移除指定元素的時候,jQuery提供了empty()與remove([expr])二個方法,兩個都是刪除元素,但是兩者還是有區(qū)別
empty方法
嚴(yán)格地講,empty()方法并不是刪除節(jié)點(diǎn),而是清空節(jié)點(diǎn),它能清空元素中的所有后代節(jié)點(diǎn)
empty不能刪除自己本身這個節(jié)點(diǎn)
remove方法
該節(jié)點(diǎn)與該節(jié)點(diǎn)所包含的所有后代節(jié)點(diǎn)將同時被刪除
提供傳遞一個篩選的表達(dá)式,刪除指定合集中的元素
以上就是二者的區(qū)別,我們具體通過下邊代碼部分加深理解
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-type" content="text/html; charset=utf-8" />
<title></title>
<script src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script>
<style>
.left,
.right {
width: 300px;
}
.left div,
.right div {
width: 100px;
height: 90px;
padding: 5px;
margin: 5px;
float: left;
border: 1px solid #ccc;
}
.left div {
background: #bbffaa;
}
.right div {
background: yellow;
}
</style>
</head>
<body>
<h2>通過empty與remove移除元素</h2>
<div class="left">
<button id="bt1">點(diǎn)擊通過jQuery的empty移除內(nèi)部P元素</button>
<button id="bt2">點(diǎn)擊通過jQuery的remove移除整個節(jié)點(diǎn)</button>
</div>
<div class="right">
<div id="test1">
<p>p元素1</p>
<p>p元素2</p>
</div>
<div id="test2">
<p>p元素3</p>
<p>p元素4</p>
</div>
</div>
<script type="text/javascript">
$("#bt1").on('click', function() {
//刪除了2個p元素,但是本著沒有刪除
$("#test1").empty()
})
$("#bt2").on('click', function() {
//刪除整個節(jié)點(diǎn)
$("#test2").remove()
})
</script>
</body>
</html>
以上這篇基于DOM節(jié)點(diǎn)刪除之empty和remove的區(qū)別(詳解)就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Jquery的hover方法讓鼠標(biāo)經(jīng)過li時背景變色
鼠標(biāo)經(jīng)過時讓li背景變色,在某些時候還是挺實(shí)用的,下面為大家介紹下使用Jquery的hover方法來實(shí)現(xiàn)下,感興趣的朋友可以參考下2013-09-09
jquery nth-child()選擇器的簡單應(yīng)用
今天項(xiàng)目中遇到過一個這樣的問題,就是希望讀出來的文章列表能夠每隔五個加一個分割條,而不是每個都加。2010-07-07
jquery 1.3.2 IE8中的一點(diǎn)點(diǎn)的小問題解決方法
最近的項(xiàng)目中開始使用了新版本的jquery,就是1.3.2版,發(fā)現(xiàn)在這個在版本對就radio類型的input在IE8中的支持不太好2009-07-07
基于jQuery實(shí)現(xiàn)文字打印動態(tài)效果
這篇文章主要介紹了基于jQuery實(shí)現(xiàn)文字打印動態(tài)效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04
jQuery實(shí)現(xiàn)div橫向拖拽排序的簡單實(shí)例
下面小編就為大家?guī)硪黄猨Query實(shí)現(xiàn)div橫向拖拽排序的簡單實(shí)例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-07-07

