JQuery DOM 复制节点

服务器君一共花费了84.336 ms进行了6次数据库查询,努力地为您提供了提供了这个页面。

复制节点也是常用的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   
    //可以复制自己,并且他的副本也有同样功能。    
}) 

在clone()方法中传递了一个参数true,它的含义是复制元素的同时复制元素中所绑定的事件。因此该元素的副本也同样具有复制功能(本例中是单击事件)。

Creative Commons License

本文仅供自己学习与收藏之用,请勿转载,请勿用作其它用途(如商业目的等)。 原文链接:http://www.nowamagic.net/librarys/posts/jquery/9