×

jQuery之dom节点操作基础玩法

作者:admin2017.12.07来源:Web前端之家浏览:1862评论:0
关键词:JQueryJSdom
微信公众号

微信公众号

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

HTML DOM结构如下:

<p class="nm_p" title="欢迎访问Web前端之家" >欢迎访问Web前端之家</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()方法来完成,代码如下:

$(function(){ 
    $(".nm_ul li").click(function(){ 
    $(this).clone(true).appendTo(".nm_ul"); // 复制当前点击的节点,并将它追加到<ul>元素 
    }) 
});
在页面中单击随便一项后,列表最下方出现该项的新节点。

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

$("ul li").click(function(){ 
    $(this).clone(true).appendTo("ul"); // 注意参数true 
    //可以复制自己,并且他的副本也有同样功能。 
})

总结:

本篇文章属于比较基础的知识,大神们可以略之。

温馨提示:本文作者系admin ,经Web前端之家编辑修改或补充,转载请注明出处和本文链接:
http://jiangweishan.com/article/jqueryDomCaozuo.html

网友评论文明上网理性发言 已有0人参与

发表评论:

最新留言

  • qlong

    mailAutoComplete插件好用。...

  • admin

    相辅相成,都可以实现TIPS提示功能,只是形式不一样。...

  • 访客

    提示插件tipso和tooltips有啥区别啊...

  • jercy

    新版网站的界面很不错~...

  • jay

    很多沟通技巧还是挺不错的。...

  • 访客

    这个可以用,可能是你程序的问题吧...

  • 访客

    能不能原创,网上一找全是这段。这没效果,复制也先自己测测好不????...

  • 访客

    谢谢楼主。。。。。。。。...

首页|JavaScript|HTML|HTML4|HTML5|CSS3|开发工具|性能优化|移动开发|前端教程|性能优化|开发工具|酷站欣赏|UI设计|前端教程

Copyright © 2013-2018 Web前端之家(www.jiangweishan.com) 版权所有 All Rights Reserved.
粤ICP备12067512号-1

Copyright Your WebSite.Some Rights Reserved.

Powered By Z-BlogPHP 1.5.2 Zero