课程咨询 :186 8716 1620      qq:2066486918

昆明Java培训 > 达内新闻 > JQuery操作dom节点
  • JQuery操作dom节点

    发布:昆明Java培训      来源:达内新闻      时间:2016-04-15

  • 昆明java培训介绍了关于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="欢迎访问脚本之家图书馆" >欢迎访问脚本之家图书馆</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()方法来完成,先来看看效果:

    效果演示

    欢迎访问脚本之家图书馆

    简单易懂的PHP魔法

    简单易懂的C魔法

    简单易懂的JavaScript魔法

    简单易懂的JQuery魔法

    JQuery代码如下:

    代码如下:

    $(function(){

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

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

    })

    });

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

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

    代码如下:

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

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

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

    })

    昆明java培训听说过这样一段话,我们在一个行业里用一万小时去专注,必然会取得不错的成绩,昆明java培训希望大家用心在这个行业里成长。

    推荐文章

上一篇:昆明java培训——Js中自动切换焦点实现

下一篇:js判断一个值在数组中

最新开班日期  |  更多

Java--零基础全日制班

Java--零基础全日制班

开班日期:11/30

Java--零基础业余班

Java--零基础业余班

开班日期:11/30

Java--周末提升班

Java--周末提升班

开班日期:11/30

Java--零基础周末班

Java--零基础周末班

开班日期:11/30

  • 网址:http://km .java.tedu.cn      地址:昆明市官渡区春城路62号证券大厦附楼6楼
  • 课程培训电话:186 8716 1620      qq:2066486918    全国服务监督电话:400-827-0010
  • 服务邮箱 ts@tedu.cn
  • 2001-2016 达内国际公司(TARENA INTERNATIONAL,INC.) 版权所有 京ICP证08000853号-56