php 把各元素一起移动,移动元素-WEB前端PHP小菜-51CTO博客

本文详细介绍了如何使用jQuery进行DOM节点的移动和复制,包括append、appendTo等方法的使用,以及在复制过程中如何处理事件绑定。示例代码展示了如何将元素移动到新的位置,以及如何在复制时保留原有的事件处理。此外,还讨论了clone方法在复制节点时是否保留事件的问题。

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

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

复制代码 代码如下:

需要把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"); // 复制当前点击的节点,并将它追加到

  • 元素

})

});

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

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

复制代码 代码如下:

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

移动节点

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

复制代码 代码如下:

Move Me!

实例

$("button").click(function(){

$(this).appendTo($("#box"));

//或者用append

$("#box").append(this);

});

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

HTML DOM结构如下:

复制代码 代码如下:

欢迎访问脚本之家图书馆

  • 简单易懂的PHP魔法
  • 简单易懂的C魔法
  • 简单易懂的JavaScript魔法
  • 简单易懂的JQuery魔法

如果单击

元素后需要再复制一个元素,可以使用clone()方法来完成,先来看看效果:

效果演示

欢迎访问脚本之家图书馆

简单易懂的PHP魔法

简单易懂的C魔法

简单易懂的JavaScript魔法

简单易懂的JQuery魔法

JQuery代码如下:

复制代码 代码如下:

$(function(){

$(".nm_ul li").click(function(){

$(this).clone(true).appendTo(".nm_ul"); // 复制当前点击的节点,并将它追加到

  • 元素

})

});

在页面中单击随便一项后,列表最下方出现该项的新节点。

复制节点后,被复制的新元素并不具有任何行为。如果需要新元素也具有复制功能(本例中是单击事件),可以使用如下JQuery代码:

复制代码 代码如下:

$("ul li").click(function(){

$(this).clone(true).appendTo("ul"); // 注意参数true

//可以复制自己,并且他的副本也有同样功能。

})

jquery之设置元素内容(移动和复制元素,使用append(),appendTo()方法)

----------

如果想把内容添加到现有内容末尾,可以利用append()命令。

append()命令语法:

append(content)

把传入的HTML片段或元素追加到所有已匹配元素的内容之后

参数

content (字符串|元素|对象)将被追加到包装集各元素的一个字符串、元素或包装集。

这个函数接受包含HTML片段的字符串、现有或新建DOM元素的引用,或Jquery元素包装集。

考虑如下简单情况:

[javascript:firstline[1]] view plaincopy$('p').append('some text');

此语句将从传入字符串而创建的HTML片段,追加到页面上所有

元素的现有内容的末尾。这个命令的更加繁杂的用法是标识DOM现有元素作为追加项。考虑如下代码:

[javascript:firstline[1]] view plaincopy$('p.appendToMe').append($("a.appendMe));

这个语句把带有类appendMe的所有链接,追加到带有类appendToMe的

元素。对原始元素的布置取决于作为追加目标的元素的数量。如果是单一的目标,则元素从原始位置删除---执行把原始元素移动到新父元素的操作。如果有多个目标,则原始元素留在原处,而原始元素的副本被追加到各个目标元素---复制操作。

如果不想追加整个包装集,也可以引用一个特定DOM元素,如下所示:

[javascript:firstline[1]] view plaincopyvartoAppend = $('a.appendMe')[0];

$('p.appendToMe').append(toAppend);

标识为toAppend的元素是被移动还是被复制,取决于标识为$('p.appendToMe')的元素的数量:如果匹配一个元素则进行移动操作,如果匹配多个元素则进行复制操作。

===

如果我们想从一个地方移动或复制元素到另一个地方,更简单的解决办法是利用appendTo()命令,该命令允许获取元素并移动到DOM里另外的地方。

appendTo()语法:

appendTo(target)

把包装集里所有元素移动到指定目标的内容的末尾

参数

target  (字符串|元素)一个包含jquery选择器的字符串,或一个DOM元素。包装集各元素将追加到target所指定的那个位置。如果多个元素与一个选择器字符串匹配,则包装集各元素将被复制并追加到与选择器匹配的每个元素。

如果目的地只标识一个目标元素,则元素被移动;如果目的地标识多个目标元素,则源元素留在原始位置,且被复制到每个目标元素。

如例:

[xhtml:firstline[1]] view plaincopy

Source elements

Target elements

操作:

[javascript:firstline[1]] view plaincopy$('#flower').appendTo('#targets p');//这是是复制

$('#car').appendTo('#targets p:first');//这个是移动

===

有几个相关命令的工作方式类似于append()和appendTo(),如:

1.prepend()和prependTo()---像append()和appendTo()那样执行,不过是在目标元素的内容之前插入源元素,而不是之后。

2.before()和insertBefore()---在目标元素之前插入元素,而不是在目标元素的第一个子元素之前。

3.after()和insertAfter()---在目标元素之后插入元素,而不是在目标元素的最后一个子元素之后。

如例:

[javascript:firstline[1]] view plaincopy$('

H1 there!

').insetAfter('p img');

这个语句创建友好的段落,并把段落副本插入到段落内每个图像元素之后。

源自:http://blog.csdn.net/fhd001/article/details/6310320

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值