复制节点也是常用的DOM操作之一,例如很多购物网站的效果,用户不仅可以通过单击商品下方的“选择”按钮购买相应的产品,也可以通过鼠标拖动商品并将其放到购物车中。这个商品拖动功能就是用的复制节点,将用户选择的商品所处的节点元素复制一次,并将其跟随鼠标移动,从而达到购物效果。
HTML DOM结构如下:
1 |
< p class = "nm_p" title = "欢迎访问简明现代魔法图书馆" >欢迎访问简明现代魔法图书馆</ p > |
3 |
< li title = 'PHP魔法' >简单易懂的PHP魔法</ li > |
4 |
< li title = 'C魔法' >简单易懂的C魔法</ li > |
5 |
< li title = 'JavaScript魔法' >简单易懂的JavaScript魔法</ li > |
6 |
< li title = 'JQuery' >简单易懂的JQuery魔法</ li > |
7 |
</ ul >
JQuery代码如下:
2 |
$( ".nm_ul li" ).click( function (){ |
3 |
$( this ).clone( true ).appendTo( ".nm_ul" ); |
在页面中单击随便一项后,列表最下方出现该项的新节点。
复制节点后,被复制的新元素并不具有任何行为。如果需要新元素也具有复制功能(本例中是单击事件),可以使用如下JQuery代码:
1 |
$( "ul li" ).click( function (){ |
2 |
$( this ).clone( true ).appendTo( "ul" ); |
在clone()方法中传递了一个参数true,它的含义是复制元素的同时复制元素中所绑定的事件。因此该元素的副本也同样具有复制功能(本例中是单击事件)。
|