JQuery删除DOM节点的方法

如果文档中某一个元素多余,那么应将其删除。JQuery提供了两种删除节点的方法,即remove()和empty()。

HTML DOM结构如下:

< p class = "nm_p" title = "欢迎访问脚本之家" >欢迎访问脚本之家</ p >
< ul class = "nm_ul" >
   < li title = 'PHP编程' >简单易懂的PHP编程</ li >
   < li title = 'C编程' >简单易懂的C编程</ li >
   < li title = 'JavaScript编程' >简单易懂的JavaScript编程</ li >
   < li title = 'JQuery' >简单易懂的JQuery编程</ li >
</ ul >

remove()方法

作用是从DOM中删除所有匹配的元素,传入的参数用于根据JQuery表达式来筛选元素。

例如删除<ul>节点中的第2个<li>元素节点,JQuery代码如下:

$( ".nm_ul li:eq(1)" ).remove();
// 获取第二个<li>元素节点后,将它从网页中删除

运行代码后效果将删掉第二个节点。

当某个节点用remove()方法删除后,该节点所包含的所有后代节点将同时被删除。这个方法的返回值是一个指向已被删除的节点的引用,因此可以在以后再使用这些元素。下面的JQuery代码说明元素用remove()方法删除后,还是可以继续使用的。

var $li = $( "nm_ul li:eq(1)" ).remove();
// 获取第二个<li>元素节点后,将它从网页中删除。
$li.appendTo( "nm_ul" );
// 把刚才删除的又重新添加到<ul>元素里
//所以,删除只是从网页中删除,在jQuery对象中,这个元素还是存在的,我们可以重新获取它

可以直接使用appendTo()方法的特性来简化以上代码,JQuery代码如下:

?
1
2
3
$( "nm_ul li:eq(1)" ).appendTo( "nm_ul" );
//appendTo()方法也可以用来移动元素
//移动元素时首先从文档上删除此元素,然后将该元素插入得到文档中的指定节点

另外remove()方法也可以通过传递参数来选择性地删除元素,JQuery代码如下:

?
1
2
// 把<li>元素中属性title不等于"菠萝"的<li>元素删除
$( "nm_ul li" ).remove( "li[title!=JQuery]" );

empty()方法

严格来讲,empty()方法并不是删除节点,而是清空节点,它能清空元素中的所有后代节点。JQuery代码如下:

?
1
2
$( "nm_ul li:eq(1)" ).empty();
// 找到第二个<li>元素节点后,清空此元素里的内容

当运行代码后,第2个<li>元素的内容被清空了,只剩下<li>标签默认的符号“.”。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值