JQuery

1个成员

jQuery移动和复制dom节点实现程序

发表于 2017-02-02 2750 次查看
本文章简单的介绍了关于jQuery移动和复制dom节点程序实现,有需要学习的朋友可参考参考。

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

 代码如下 复制代码

<div></div>

<p></p>

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

 代码如下 复制代码

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

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

 代码如下 复制代码

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

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

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

 代码如下 复制代码

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

 代码如下 复制代码

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

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


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

 代码如下 复制代码

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

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

 代码如下 复制代码

<button>Move Me!</button>
<div id="box"></div>

实例

$("button").click(function(){
 $(this).appendTo($("#box"));
 //或者用append
 $("#box").append(this);
});

发表回复
你还没有登录,请先登录注册