jQuery DOM操作のコピー
Clone ノードは DOM の一般的な操作です。jQuery は dom のクローン作成を処理するために特別に使用される clone メソッドを提供します。このメソッドは、すべての一致する要素、従属要素を含む、すべての一致する要素セットを深くコピーします。一致する要素のテキスト ノード。
clone メソッドは比較的単純で、ノードのクローンを作成するだけですが、ノードにイベントやデータなどの他の処理がある場合は、 clone(ture) を介してブール値 ture を渡して指定する必要があることに注意してください。これはノードの単純なクローンではなく、付属のイベントとデータを一緒にクローンする必要があります例:
HTML部分 <div></div> JavaScript部分 $("div").on('click', function() {//执行操作}) //clone处理一 $("div").clone() //只克隆了结构,事件丢失 //clone处理二 $("div").clone(true) //结构、事件与数据都克隆
クローンを使用する場合は、追加の詳細を知る必要があります。
clone() メソッドに挿入する場合 ドキュメントを入力する前に、クローンされた要素または要素のコンテンツを変更できます。たとえば、右側のコードでは、 I $(this).clone().css('color' ,'red') 色を追加します true を渡すと、元の要素にバインドされたイベント処理関数がクローン化された要素にコピーされます clone() メソッドは jQuery 拡張機能であり、バインドされたイベントとデータのみを処理できますjQuery 要素データ(data)内のオブジェクトと配列はコピーされず、クローン要素と元の要素の間で引き続き共有されます。ディープコピー内のすべてのデータは手動でコピーする必要があります以下に例を書いてみましょう:<!DOCTYPE html> <html> <head> <meta http-equiv="Content-type" content="text/html; charset=utf-8" /> <title></title> <script src="http://lib.sinaapp.com/js/jquery/1.9.1/jquery-1.9.1.min.js"></script> <style> .left, .right { width: 300px; height: 120px; } .left div, .right div { width: 100px; height: 90px; padding: 5px; margin: 5px; float: left; border: 1px solid #ccc; background: #bbffaa; } </style> </head> <body> <div class="left"> <div class="aaron1">点击,clone浅拷贝</div> <div class="aaron2">点击,clone深拷贝,可以继续触发创建</div> </div> <script type="text/javascript"> //只克隆节点 //不克隆事件 $(".aaron1").on('click', function() { $(".left").append( $(this).clone().css('color','red') ) }) </script> <script type="text/javascript"> //克隆节点 //克隆事件 $(".aaron2").on('click', function() { console.log(1) $(".left").append( $(this).clone(true).css('color','blue') ) }) </script> </body> </html>上記のコードを見てください。最初の div をクリックするとコピーされますが、クリックしてコピーすると、効果はありません、試してみてください