深度理解DOM拷貝clone()

  • 2019 年 10 月 6 日
  • 筆記

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

.clone()方法深度 複製所有匹配的元素集合,包括所有匹配元素、匹配元素的下級元素、文位元組點。

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

例如:

HTML部分  <div></div>    JavaScript部分  $("div").on('click', function() {//執行操作})    //clone處理一  $("div").clone()   //只克隆了結構,事件丟失    //clone處理二  $("div").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 div,      .right div {          width: 100px;          height: 90px;          padding: 5px;          margin: 5px;          float: left;          border: 1px solid #ccc;          background: #bbffaa;      }      </style>  </head>    <body>      <h2>通過clone克隆元素</h2>      <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>