欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jQuery移动和复制dom节点实用DOM操作案例

程序员文章站 2022-04-15 10:50:31
在做一个项目时,需要dom节点移动,如以下代码: . 代码如下:

需要把p标签移动到p标签里,经过测试发现,在jq...

在做一个项目时,需要dom节点移动,如以下代码:

. 代码如下:


<p></p>
<p></p>


需要把p标签移动到p标签里,经过测试发现,在jquery中移动dom节点非常方便:

. 代码如下:


$('p').append($('p'))


这样即可把p标签移动到p标签里,千万不要写成这样:

. 代码如下:


$('p').append( $('p').html() )


这样只是把p标签里的内容复制到p标签里。

 

如果只是复制一份到p标签里,原来的标签还保留着,那么可以这么写:

. 代码如下:


$('p').append( $('p').clone(true))



. 代码如下:


$(function(){
$(".nm_ul li").click(function(){
$(this).clone(true).appendto(".nm_ul"); // 复制当前点击的节点,并将它追加到<ul>元素
})
});


而且当clone参数设置为true时还可以将按钮上绑定的事件一起复制到新按钮上

 

在clone()方法中传递了一个参数true,它的含义是复制元素的同时复制元素中所绑定的事件。因此该元素的副本也同样具有复制功能。如果不希望事件也被复制,则可以这么写:

. 代码如下:


$('p').append( $('p').clone())


移动节点
将页面上的一个节点移动到另外一个地方可以用jq的内部和外部插入方法(append,appendto,prepend,prependto,after,before,insertafter,insertbefore),直接将选中的节点传递进去就可以实现移动

. 代码如下:


<button>move me!</button>
<p id="box"></p>
实例
$("button").click(function(){
$(this).appendto($("#box"));
//或者用append
$("#box").append(this);
});


复制节点也是常用的dom操作之一,例如很多购物网站的效果,用户不仅可以通过单击商品下方的“选择”按钮购买相应的产品,也可以通过鼠标拖动商品并将其放到购物车中。这个商品拖动功能就是用的复制节点,将用户选择的商品所处的节点元素复制一次,并将其跟随鼠标移动,从而达到购物效果。
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>


如果单击<li>元素后需要再复制一个<li>元素,可以使用clone()方法来完成,先来看看效果:
效果演示
欢迎访问脚本之家图书馆
简单易懂的php魔法
简单易懂的c魔法
简单易懂的javascript魔法
简单易懂的jquery魔法
jquery代码如下:

. 代码如下:


$(function(){
$(".nm_ul li").click(function(){
$(this).clone(true).appendto(".nm_ul"); // 复制当前点击的节点,并将它追加到<ul>元素
})
});


在页面中单击随便一项后,列表最下方出现该项的新节点。
复制节点后,被复制的新元素并不具有任何行为。如果需要新元素也具有复制功能(本例中是单击事件),可以使用如下jquery代码:

. 代码如下:


$("ul li").click(function(){
$(this).clone(true).appendto("ul"); // 注意参数true
//可以复制自己,并且他的副本也有同样功能。
})