jQuery中DOM节点的删除方法总结(超全面)


Posted in Javascript onJanuary 22, 2017

前言

相信大家都知道,要移除页面上节点是开发者常见的操作,jQuery提供了几种不同的方法用来处理这个问题。下面本文就进行一个详细的介绍,感兴趣的朋友们一起来看看吧。

一、empty

empty 顾名思义,清空方法,但是与删除又有点不一样,因为它只移除了 指定元素中的所有子节点。

这个方法不仅移除子元素(和其他后代元素),同样移除元素里的文本。因为,根据说明,元素里任何文本字符串都被看做是该元素的子节点。如果我们通过empty方法移除里面div的所有元素,它只是清空内部的html代码,但是标记仍然留在DOM中,通过empty移除了当前div元素下的所有p元素 但是本身id=test的div元素没有被删除。

$("button").on('click', function() {
 //通过empty移除了当前div元素下的所有p元素
 //但是本身id=test的div元素没有被删除
 $("#test").empty()
 })

二、remove

remove与empty一样,都是移除元素的方法,但是remove会将元素自身移除,同时也会移除元素内部的一切,包括绑定的事件及与该元素相关的jQuery数据。

例如一段节点,绑定点击事件,如果不通过remove方法删除这个节点其实也很简单,但是同时需要把事件给销毁掉,这里是为了防止"内存泄漏",所以前端开发者一定要注意,绑了多少事件,不用的时候一定要记得销毁。通过remove方法移除div及其内部所有元素,remove内部会自动操作事件销毁方法,所以使用使用起来非常简单

remove表达式参数:

remove比empty好用的地方就是可以传递一个选择器表达式用来过滤将被移除的匹配元素集合,可以选择性的删除指定的节点,我们可以通过$()选择一组相同的元素,然后通过remove()传递筛选的规则,如:$("p").filter(":contains('3')").remove()

<body>
 <style>
 .test1 {
 background: #bbffaa;
 }
 
 .test2 {
 background: yellow;
 }
 </style>
 <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>点击通过jQuery的empty移除元素</button>
 <button>点击通过jQuery的empty移除指定元素</button>
 <script type="text/javascript">
 $("button:first").on('click', function() {
 //删除整个 class=test1的div节点
 $(".test1").remove()
 })

 $("button:last").on('click', function() {
 //找到所有p元素中,包含了3的元素
 //这个也是一个过滤器的处理
 $("p").remove(":contains('3')")
 })
 </script>
</body>

empty和remove区别

用到移除指定元素的时候,jQuery提供了empty()remove([expr])二个方法,两个都是删除元素,但是两者还是有区别

empty方法

  • 严格地讲,empty()方法并不是删除节点,而是清空节点,它能清空元素中的所有后代节点
  • empty不能删除自己本身这个节点

remove方法

  • 该节点与该节点所包含的所有后代节点将同时被删除
  • 提供传递一个筛选的表达式,用来指定删除选中合集中的元素

三、detach

如果我们希望临时删除页面上的节点,但是又不希望节点上的数据与事件丢失,并且能在下一个时间段让这个删除的节点显示到页面,这时候就可以使用detach方法来处理detach从字面上就很容易理解。让一个web元素托管。即从当前页面中移除该元素,但保留这个元素的内存模型对象。

官方解释:这个方法不会把匹配的元素从jQuery对象中删除,因而可以在将来再使用这些匹配的元素。与remove()不同的是,所有绑定的事件、附加的数据等都会保留下来。 $("div").detach()这一句会移除对象,仅仅是显示效果没有了。但是内存中还是存在的。当你append之后,又重新回到了文档流中。就又显示出来了。

当然这里要特别注意,detach方法是JQuery特有的,所以它只能处理通过JQuery的方法绑定的事件或者数据

通过 $("p").detach()把所有的P元素元素删除后,在通过append把删除的p放到页面上,可以通过点击文字测试,事件没有丢失

<body>
 <p>P元素1,默认给绑定一个点击事件</p>
 <p>P元素2,默认给绑定一个点击事件</p>
 <button id="bt1">点击删除 p 元素</button>
 <button id="bt2">点击移动 p 元素</button>
 <script type="text/javascript">
 $('p').click(function(e) {
 alert(e.target.innerHTML)
 })
 var p;
 $("#bt1").click(function() {
 if (!$("p").length) return; //去重
 //通过detach方法删除元素
 //只是页面不可见,但是这个节点还是保存在内存中
 //数据与事件都不会丢失
 p = $("p").detach()
 });

 $("#bt2").click(function() {
 //把p元素在添加到页面中
 //事件还是存在
 $("body").append(p);
 });
 </script>
</body>

detach()和remove()区别

JQuery是一个很大强的工具库,在工作中开发中,可是有些方法还是因为不常用到,或是没有注意到而被我们而忽略。remove()detach()可能就是其中的一个,可能remove()我们用得比较多,而detach()就可能会很少了

通过一张对比表来解释2个方法之间的不同 

方法名 参数 事件及数据是否也被移除 元素自身是否被移除
remove 支持选择器表达 是(无参数时),有参数时要根据参数所涉及的范围
detach 参数同remove 情况同remove

remove:移除节点

  • 无参数,移除自身整个节点以及该节点的内部的所有节点,包括节点上事件与数据
  • 有参数,移除筛选出的节点以及该节点的内部的所有节点,包括节点上事件与数据

detach:移除节点

  • 移除的处理与remove一致
  • remove()不同的是,所有绑定的事件、附加的数据等都会保留下来
  • 例如:$("p").detach()这一句会移除对象,仅仅是显示效果没有了。但是内存中还是存在的。当你append之后,又重新回到了文档流中。就又显示出来了。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
JavaScript 中的replace方法说明
Apr 13 Javascript
jQuery '行 4954 错误: 不支持该属性或方法' 的问题解决方法
Jan 19 Javascript
jquery 操作DOM的基本用法分享
Apr 05 Javascript
判断文件是否正在被使用的JS代码
Dec 21 Javascript
JS的参数传递示例介绍
Feb 08 Javascript
jQuery实现漂亮实用的商品图片tips提示框效果(无图片箭头+阴影)
Apr 16 Javascript
浅谈js和css内联外联注意事项
Jun 30 Javascript
JavaScript数据结构之链表的实现
Mar 19 Javascript
jQuery实现简单的滑动导航代码(移动端)
May 22 jQuery
Agularjs妙用双向数据绑定实现手风琴效果
May 26 Javascript
微信小程序实现默认第一个选中变色效果
Jul 17 Javascript
微信小程序-form表单提交代码实例
Apr 29 Javascript
js实现贪吃蛇小游戏(容易理解)
Jan 22 #Javascript
JS常见简单正则表达式验证功能小结【手机,地址,企业税号,金额,身份证等】
Jan 22 #Javascript
利用CSS、JavaScript及Ajax实现图片预加载的三大方法
Jan 22 #Javascript
js实现图片360度旋转
Jan 22 #Javascript
Vue 过渡(动画)transition组件案例详解
Jan 22 #Javascript
BootstrapTable请求数据时设置超时(timeout)的方法
Jan 22 #Javascript
boostrapTable的refresh和refreshOptions区别浅析
Jan 22 #Javascript
You might like
图形数字验证代码
2006/10/09 PHP
一些 PHP 管理系统程序中的后门
2009/08/05 PHP
浅谈php中mysql与mysqli的区别分析
2013/06/10 PHP
完美解决令人抓狂的zend studio 7代码提示(content Assist)速度慢的问题
2013/06/20 PHP
CodeIgniter实现更改view文件夹路径的方法
2014/07/04 PHP
CodeIgniter模板引擎使用实例
2014/07/15 PHP
PHP使用fopen与file_get_contents读取文件实例分享
2016/03/04 PHP
php把时间戳转换成多少时间之前函数的实例
2016/11/16 PHP
jQuery EasyUI API 中文文档 可调整尺寸
2011/09/29 Javascript
js查找某元素中的所有图片地址的方法
2014/01/16 Javascript
Nodejs Post请求报socket hang up错误的解决办法
2014/09/25 NodeJs
javascript实现淡蓝色的鼠标拖动选择框实例
2015/05/09 Javascript
jQuery支持添加事件的日历特效代码分享(3种样式)
2015/08/24 Javascript
Node.js+ES6+dropload.js实现移动端下拉加载实例
2017/06/01 Javascript
ES6深入理解之“let”能替代”var“吗?
2017/06/28 Javascript
Vim快速合并行及vim 将文件所有行合并到一行
2017/11/27 Javascript
浅析从vue源码看观察者模式
2018/01/29 Javascript
vue slot与传参实例代码讲解
2019/04/28 Javascript
Vue 中使用富文本编译器wangEditor3的方法
2019/09/26 Javascript
vue动态设置页面title的方法实例
2020/08/23 Javascript
Vue组件生命周期运行原理解析
2020/11/25 Vue.js
Python os模块学习笔记
2015/06/21 Python
Python获取本机所有网卡ip,掩码和广播地址实例代码
2018/01/22 Python
Python的多维空数组赋值方法
2018/04/13 Python
python脚本生成caffe train_list.txt的方法
2018/04/27 Python
Python面向对象之类和对象属性的增删改查操作示例
2018/12/14 Python
基于Python新建用户并产生随机密码过程解析
2019/10/08 Python
Python双链表原理与实现方法详解
2020/02/22 Python
玩转CSS3色彩
2010/01/16 HTML / CSS
Tory Burch英国官方网站:美国时尚生活品牌
2017/12/06 全球购物
Booking.com亚太地区:Booking.com APAC
2020/02/07 全球购物
卫校毕业生自我鉴定
2013/10/31 职场文书
表彰先进的通报
2014/01/31 职场文书
2014年幼儿园安全工作总结
2014/11/10 职场文书
2016党员干部反腐倡廉心得体会
2016/01/13 职场文书
MySQL into_Mysql中replace与replace into用法案例详解
2021/09/14 MySQL