您好,登錄后才能下訂單哦!
小編給大家分享一下jquery中克隆方法是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
jquery有克隆方法,即clone()方法。clone()方法是專門用于處理dom的克隆,可以生成被選元素的副本,包含子節點、文本和屬性;語法“$(selector).clone(true|false)”,true規定需復制事件處理程序。
克隆節點是DOM的常見操作,jQuery提供一個clone方法,專門用于處理dom的克隆
.clone()方法深度 復制所有匹配的元素集合,包括所有匹配元素、匹配元素的下級元素、文字節點。
clone方法比較簡單就是克隆節點,但是需要注意,如果節點有事件或者數據之類的其他處理,我們需要通過clone(ture)傳遞一個布爾值ture用來指定,這樣不僅僅只是克隆單純的節點結構,還要把附帶的事件與數據給一并克隆了。
語法
$(selector).clone(true|false)
參數:
true 規定需復制事件處理程序。
false 默認。規定不復制事件處理程序。
例如:
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> <h3>通過clone克隆元素</h3> <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>
以上是jquery中克隆方法是什么的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。