亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

jQuery DOM 操作之複製

克隆節(jié)點(diǎn)是DOM的常見操作,jQuery提供一個(gè)clone方法,專門用於處理dom的克隆

.clone() 方法深度複製所有匹配的元素集合,包括所有符合元素、符合元素的下級(jí)元素、文字節(jié)點(diǎn)。

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

例如:

HTML部分
<div></div>

JavaScript部分
$("div").on('click', function() {//執(zhí)行操作})

//clone處理一
$("div").clone()   //只克隆了結(jié)構(gòu),事件丟失

//clone處理二
$("div").clone(true) //結(jié)構(gòu)、事件與數(shù)據(jù)都克隆

使用上就是這樣簡(jiǎn)單,使用克隆的我們需要額外知道的細(xì)節(jié):

????clone()方法時(shí),在將它插入文件之前,我們可以修改克隆後的元素或元素內(nèi)容,如右邊程式碼我$(this).clone().css('color', 'red') 增加了一個(gè)顏色

????透過傳遞true,將所有綁定在原始元素上的事件處理函數(shù)複製到克隆元素上

????clone()方法是jQuery擴(kuò)展的,只能處理透過jQuery綁定的事件與資料

????元素資料(data)內(nèi)物件和陣列不會(huì)被複製,將繼續(xù)被複製元素和原始元素共用。深複製的所有數(shù)據(jù),需要手動(dòng)複製每一個(gè)

下面我們來寫一個(gè)實(shí)例:

<!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">點(diǎn)擊,clone淺拷貝</div>
        <div class="aaron2">點(diǎn)擊,clone深拷貝,可以繼續(xù)觸發(fā)創(chuàng)建</div>
    </div>
    <script type="text/javascript">
        //只克隆節(jié)點(diǎn)   //不克隆事件
        $(".aaron1").on('click', function() {
            $(".left").append( $(this).clone().css('color','red') )
        })
    </script>

    <script type="text/javascript">
        //克隆節(jié)點(diǎn)   //克隆事件
        $(".aaron2").on('click', function() {
            console.log(1)
            $(".left").append( $(this).clone(true).css('color','blue') )
        })
    </script>
</body>

</html>

大家看以上代碼,當(dāng)我點(diǎn)擊第一個(gè)div時(shí),是被複製了一個(gè),但是你點(diǎn)選複製出來的時(shí)候,是沒有效果的,大家可以試試看

#
繼續(xù)學(xué)習(xí)
||
<!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">點(diǎn)擊,clone淺拷貝</div> <div class="aaron2">點(diǎn)擊,clone深拷貝,可以繼續(xù)觸發(fā)創(chuàng)建</div> </div> <script type="text/javascript"> //只克隆節(jié)點(diǎn) //不克隆事件 $(".aaron1").on('click', function() { $(".left").append( $(this).clone().css('color','red') ) }) </script> <script type="text/javascript"> //克隆節(jié)點(diǎn) //克隆事件 $(".aaron2").on('click', function() { console.log(1) $(".left").append( $(this).clone(true).css('color','blue') ) }) </script> </body> </html>
提交重置程式碼