[jQuery教程]DOM节点删除方法(六)
empty()的基本用法
要移除页面上节点是开发者常见的操作,jQuery 提供了几种不同的方法用来处理这个问题,这里我们开仔细了解下 empty 方法
empty 顾名思义,清空方法,但是与删除又有点不一样,因为它只移除了 指定元素中的所有子节点。
这个方法不仅移除子元素(和其他后代元素),同样移除元素里的文本。因为,根据说明,元素里任何文本字符串都被看做是该元素的子节点。请看下面的 HTML:
<div class="hello"><p>码云笔记</p></div>
如果我们通过 empty 方法移除里面 div 的所有元素,它只是清空内部的 html 代码,但是标记仍然留在 DOM 中。
//通过 empty 处理 $('.hello').empty(); //结果:<p>码云笔记</p>被移除 <div class="hello"></div>
通过 empty 移除了当前 div 元素下的所有 p 元素,但是本身 id=test 的 div 元素没有被删除。
remove()的有参用法和无参用法
remove 与 empty 一样,都是移除元素的方法,但是 remove 会将元素自身移除,同时也会移除元素内部的一切,包括绑定的事件及与该元素相关的 jQuery 数据。
例如一段节点,绑定点击事件
<div class="hello"><p>码云笔记</p></div> $('.hello').on("click",fn)
如果不通过 remove 方法删除这个节点其实也很简单,但是同时需要把事件给销毁掉,这里是为了防止”内存泄漏”,所以前端开发者一定要注意,绑了多少事件,不用的时候一定要记得销毁。
通过 remove 方法移除 div 及其内部所有元素,remove 内部会自动操作事件销毁方法,所以使用使用起来非常简单。
//通过 remove 处理 $('.hello').remove() //结果:<div class="hello"><p>码云笔记</p></div> 全部被移除 //节点不存在了,同事事件也会被销毁
remove 表达式参数:
remove 比 empty 好用的地方就是可以传递一个选择器表达式用来过滤将被移除的匹配元素集合,可以选择性的删除指定的节点
我们可以通过$()选择一组相同的元素,然后通过 remove()传递筛选的规则,从而这样处理
empty 和 remove 区别
要用到移除指定元素的时候,jQuery 提供了 empty()与 remove([expr])二个方法,两个都是删除元素,但是两者还是有区别
empty 方法:
- 严格地讲,empty()方法并不是删除节点,而是清空节点,它能清空元素中的所有后代节点
- empty 不能删除自己本身这个节点
remove 方法:
- 该节点与该节点所包含的所有后代节点将同时被删除
- 提供传递一个筛选的表达式,删除指定合集中的元素
保留数据的删除操作 detach()
如果我们希望临时删除页面上的节点,但是又不希望节点上的数据与事件丢失,并且能在下一个时间段让这个删除的节点显示到页面,这时候就可以使用 detach 方法来处理
detach 从字面上就很容易理解。让一个 web 元素托管。即从当前页面中移除该元素,但保留这个元素的内存模型对象。
来看看 jquery 官方文档的解释:
这个方法不会把匹配的元素从 jQuery 对象中删除,因而可以在将来再使用这些匹配的元素。与 remove()不同的是,所有绑定的事件、附加的数据等都会保留下来。
$(“div”).detach()这一句会移除对象,仅仅是显示效果没有了。但是内存中还是存在的。当你 append 之后,又重新回到了文档流中。就又显示出来了。
当然这里要特别注意,detach 方法是 JQuery 特有的,所以它只能处理通过 JQuery 的方法绑定的事件或者数据。
detach()和 remove()区别
JQuery 是一个很大强的工具库,在工作开发中,有些方法因为不常用到,或是没有注意到而被我们忽略。
remove()和 detach()可能就是其中的一个,可能 remove()我们用得比较多,而 detach()就可能会很少了。
通过一张对比表来解释 2 个方法之间的不同:
remove:移除节点
- 无参数,移除自身整个节点以及该节点的内部的所有节点,包括节点上事件与数据;
- 有参数,移除筛选出的节点以及该节点的内部的所有节点,包括节点上事件与数据。
detach:移除节点
- 移除的处理与 remove 一致;
- 与 remove()不同的是,所有绑定的事件、附加的数据等都会保留下来;
- 例如:$(“p”).detach()这一句会移除对象,仅仅是显示效果没有了。但是内存中还是存在的。当你 append 之后,又重新回到了文档流中。就又显示出来了。
码云笔记 » [jQuery教程]DOM节点删除方法(六)