克隆節點是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> <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時,是被複製了一個,但是你點選複製出來的時候,是沒有效果的,大家可以試試看