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

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

----------

如果想把内容添加到现有内容末尾,可以利用append()命令。
append()命令语法:
append(content)
把传入的HTML片段或元素追加到所有已匹配元素的内容之后
参数
content (字符串|元素|对象)将被追加到包装集各元素的一个字符串、元素或包装集。
这个函数接受包含HTML片段的字符串、现有或新建DOM元素的引用,或Jquery元素包装集。
考虑如下简单情况:

[javascript:firstline[1]]  view plain copy
  1. $('p').append('<b>some text<b>');  

此语句将从传入字符串而创建的HTML片段,追加到页面上所有<p>元素的现有内容的末尾。这个命令的更加繁杂的用法是标识DOM现有元素作为追加项。考虑如下代码:

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

这个语句把带有类appendMe的所有链接,追加到带有类appendToMe的<p>元素。对原始元素的布置取决于作为追加目标的元素的数量。如果是单一的目标,则元素从原始位置删除---执行把原始元素移动到新父元素的操作。如果有多个目标,则原始元素留在原处,而原始元素的副本被追加到各个目标元素---复制操作。
如果不想追加整个包装集,也可以引用一个特定DOM元素,如下所示:

[javascript:firstline[1]]  view plain copy
  1. var toAppend = $('a.appendMe')[0];  
  2. $('p.appendToMe').append(toAppend);  

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

===

如果我们想从一个地方移动或复制元素到另一个地方,更简单的解决办法是利用appendTo()命令,该命令允许获取元素并移动到DOM里另外的地方。
appendTo()语法:
appendTo(target)
把包装集里所有元素移动到指定目标的内容的末尾
参数
target  (字符串|元素)一个包含jquery选择器的字符串,或一个DOM元素。包装集各元素将追加到target所指定的那个位置。如果多个元素与一个选择器字符串匹配,则包装集各元素将被复制并追加到与选择器匹配的每个元素。

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

[xhtml:firstline[1]]  view plain copy
  1. <fieldset id="source">  
  2.   <legend>Source elements</legend>  
  3.   <img id="flower" src="flower.png" mce_src="flower.png"/>  
  4.   <img id="car" src="car.png" mce_src="car.png"/>  
  5. </fieldset>  
  6. <fieldset id="targets">  
  7.   <legend>Target elements</legend>  
  8.   <p><img src="dragonfly.png" mce_src="dragonfly.png"/></p>  
  9.   <p><img src="dragonfly.png" mce_src="dragonfly.png"/></p>  
  10.   <p><img src="dragonfly.png" mce_src="dragonfly.png"/></p>  
  11. </fieldset>  

操作:

[javascript:firstline[1]]  view plain copy
  1. $('#flower').appendTo('#targets p');              //这是是复制  
  2. $('#car').appendTo('#targets p:first');           //这个是移动  

 

===

有几个相关命令的工作方式类似于append()和appendTo(),如:
1.prepend()和prependTo()---像append()和appendTo()那样执行,不过是在目标元素的内容之前插入源元素,而不是之后。
2.before()和insertBefore()---在目标元素之前插入元素,而不是在目标元素的第一个子元素之前。
3.after()和insertAfter()---在目标元素之后插入元素,而不是在目标元素的最后一个子元素之后。
如例:

[javascript:firstline[1]]  view plain copy
  1. $('<p>H1 there!</p>').insetAfter('p img');  

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

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

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值