首頁  >  文章  >  web前端  >  如何理解DOM拷貝clone()

如何理解DOM拷貝clone()

一个新手
一个新手原創
2017-09-30 09:23:591442瀏覽

克隆節點是DOM的常見操作,jQuery提供一個clone方法,專門用來處理dom的複製:


.clone()方法深度 复制所有匹配的元素集合,包括所有匹配元素、匹配元素的下级元素、文字节点。

clone方法比較簡單就是複製節點,但是要注意,如果節點有事件或資料之類的其他處理,我們需要透過clone(ture)傳遞一個布林值ture用來指定,這樣不只複製單純的節點結構,還要把附帶的事件與資料給一併克隆了

例如:


HTML部分<p></p>JavaScript部分
$("p").on(&#39;click&#39;, function() {//执行操作})

//clone处理一
$("p").clone()   //只克隆了结构,事件丢失

//clone处理二
$("p").clone(true) //结构、事件与数据都克隆

使用上就是這樣簡單,使用複製的我們需要額外知道的細節:

  • clone()方法時,在將它插入到文件之前,我們可以修改複製後的元素或元素內容,如右邊程式碼我$(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 p,
    .right p {
        width: 100px;
        height: 90px;
        padding: 5px;
        margin: 5px;
        float: left;
        border: 1px solid #ccc;
        background: #bbffaa;
    }
    </style></head><body>
    <h2>通过clone克隆元素</h2>
    <p class="left">
        <p class="aaron1">点击,clone浅拷贝</p>
        <p class="aaron2">点击,clone深拷贝,可以继续触发创建</p>
    </p>
    <script type="text/javascript">
        //只克隆节点
        //不克隆事件        $(".aaron1").on(&#39;click&#39;, function() {
            $(".left").append( $(this).clone().css(&#39;color&#39;,&#39;red&#39;) )
        })    </script>

    <script type="text/javascript">
        //克隆节点
        //克隆事件        $(".aaron2").on(&#39;click&#39;, function() {
            console.log(1)
            $(".left").append( $(this).clone(true).css(&#39;color&#39;,&#39;blue&#39;) )
        })    </script></body></html>

以上是如何理解DOM拷貝clone()的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn