jQuery之dom节点操作基础玩法,实现jQuery移动和复制dom节点程序,属于比较基础的知识。
在做一个项目时,需要dom节点移动,如以下代码:
<div></div> <p></p>
$('div').append($('p'))
这样即可把p标签移动到div标签里,千万不要写成这样:
$('div').append( $('p').html() )
如果只是复制一份到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); });
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 //可以复制自己,并且他的副本也有同样功能。 })
总结:
本篇文章属于比较基础的知识,大神们可以略之。
网友评论文明上网理性发言 已有0人参与
发表评论: