老生常談jquery中detach()和remove()的區(qū)別
JQuery是一個(gè)很大強(qiáng)的工具庫,在工作中開發(fā)中,可是有些方法還是因?yàn)椴怀S玫?,或是沒有注意到而被我們而忽略。
remove()和detach()可能就是其中的一個(gè),可能remove()我們用得比較多,而detach()就可能會(huì)很少了
通過一張對比表來解釋2個(gè)方法之間的不同
|
方法名 |
參數(shù) |
事件及數(shù)據(jù)是否也被移除 |
元素自身是否被移除 |
|
remove |
支持選擇器表達(dá) |
是 |
是(無參數(shù)時(shí)),有參數(shù)時(shí)要根據(jù)參數(shù)所涉及的范圍 |
|
detach |
參數(shù)同remove |
否 |
情況同remove |
remove:移除節(jié)點(diǎn)
- 無參數(shù),移除自身整個(gè)節(jié)點(diǎn)以及該節(jié)點(diǎn)的內(nèi)部的所有節(jié)點(diǎn),包括節(jié)點(diǎn)上事件與數(shù)據(jù)
- 有參數(shù),移除篩選出的節(jié)點(diǎn)以及該節(jié)點(diǎn)的內(nèi)部的所有節(jié)點(diǎn),包括節(jié)點(diǎn)上事件與數(shù)據(jù)
detach:移除節(jié)點(diǎn)
- 移除的處理與remove一致
- 與remove()不同的是,所有綁定的事件、附加的數(shù)據(jù)等都會(huì)保留下來
- 例如:$("p").detach()這一句會(huì)移除對象,僅僅是顯示效果沒有了。但是內(nèi)存中還是存在的。當(dāng)你append之后,又重新回到了文檔流中。就又顯示出來了。
eq:
<html>
<head>
<meta http-equiv="Content-type" content="text/html; charset=utf-8"/>
<style type="text/css">
p {
border: 1px solid red;
}
</style>
<script src="http://libs.baidu.com/jquery/1.9.1/jquery.js"></script>
</head>
<body>
<h3>給頁面2個(gè)p元素節(jié)點(diǎn)綁定點(diǎn)擊事件,點(diǎn)擊后彈出自己本身的節(jié)點(diǎn)內(nèi)容</h3>
<p>元素p1,同時(shí)綁定點(diǎn)擊事件</p>
<p>元素p2,同時(shí)綁定點(diǎn)擊事件</p>
<h3>通過點(diǎn)擊2個(gè)按鈕后觀察方法處理的區(qū)別</h3>
<button>點(diǎn)擊通過remove處理元素p1</button>
<button>點(diǎn)擊通過detach處理元素p2</button>
</body>
<script type="text/javascript">
//給頁面上2個(gè)p元素都綁定時(shí)間
$('p').click(function (e) {
alert(e.target.innerHTML)
})
$("button:first").click(function () {
var p = $("p:first").remove();
p.css('color', 'red').html('p1通過remove處理后,點(diǎn)擊該元素,事件丟失')
$("body").append(p);
});
$("button:last").click(function () {
var p = $("p:first").detach();
p.css('color', 'blue').text('p2通過detach處理后,點(diǎn)擊該元素事件存在')
$("body").append(p);
});
</script>
</script>
</html >
以上這篇老生常談jquery中detach()和remove()的區(qū)別就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- PHP isset()與empty()的使用區(qū)別詳解
- jQuery刪除節(jié)點(diǎn)的三個(gè)方法即remove()detach()和empty()
- php empty,isset,is_null判斷比較(差異與異同)
- jQuery使用empty()方法刪除元素及其所有子元素的方法
- javascript Array.remove() 數(shù)組刪除
- jquery之empty()與remove()區(qū)別說明
- 淺談java Iterator.remove()方法的用法(詳解)
- jQuery remove()過濾被刪除的元素(推薦)
- 清空元素html("") innerHTML="" 與 empty()的區(qū)別和應(yīng)用(推薦)
相關(guān)文章
淺談jquery上下滑動(dòng)的注意事項(xiàng)
下面小編就為大家?guī)硪黄猨query上下滑動(dòng)的注意事項(xiàng)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10
jquery實(shí)現(xiàn)圖片輪播和滑動(dòng)效果
這篇文章主要為大家詳細(xì)介紹了jquery實(shí)現(xiàn)圖片輪播和滑動(dòng)效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01
js/jquery獲取瀏覽器窗口可視區(qū)域高度和寬度以及滾動(dòng)條高度實(shí)現(xiàn)代碼
在js使用過程中可能會(huì)根據(jù)要求獲取瀏覽器窗口的可視區(qū)域高度和寬度,滾動(dòng)條高度,于是本人搜集整理下,拿出來和大家分享,希望可以幫助你們2012-12-12
jQuery實(shí)現(xiàn)的事件綁定功能基本示例
這篇文章主要介紹了jQuery實(shí)現(xiàn)的事件綁定功能,結(jié)合簡單表單驗(yàn)證實(shí)例分析了jQuery事件綁定的實(shí)現(xiàn)與使用方法,需要的朋友可以參考下2017-10-10
jqueryMobile 動(dòng)態(tài)添加元素,展示刷新視圖的實(shí)現(xiàn)方法
下面小編就為大家?guī)硪黄猨queryMobile 動(dòng)態(tài)添加元素,展示刷新視圖的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-05-05
jquery實(shí)現(xiàn)聯(lián)想詞搜索框和搜索結(jié)果分頁的示例
今天小編就為大家分享一篇jquery實(shí)現(xiàn)聯(lián)想詞搜索框和搜索結(jié)果分頁的示例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-10-10

