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 をクリックするとコピーされますが、クリックしてコピーすると、効果はありません、試してみてください

学び続ける
||
<!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>
  • おすすめコース
  • コースウェアのダウンロード
現時点ではコースウェアはダウンロードできません。現在スタッフが整理中です。今後もこのコースにもっと注目してください〜