jquery中克隆方法是什么-創(chuàng)新互聯(lián)

小編給大家分享一下jquery中克隆方法是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

山陽(yáng)網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián),山陽(yáng)網(wǎng)站設(shè)計(jì)制作,有大型網(wǎng)站制作公司豐富經(jīng)驗(yàn)。已為山陽(yáng)上千余家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)網(wǎng)站制作要多少錢(qián),請(qǐng)找那個(gè)售后服務(wù)好的山陽(yáng)做網(wǎng)站的公司定做!

jquery有克隆方法,即clone()方法。clone()方法是專門(mén)用于處理dom的克隆,可以生成被選元素的副本,包含子節(jié)點(diǎn)、文本和屬性;語(yǔ)法“$(selector).clone(true|false)”,true規(guī)定需復(fù)制事件處理程序。

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

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


clone方法比較簡(jiǎn)單就是克隆節(jié)點(diǎn),但是需要注意,如果節(jié)點(diǎn)有事件或者數(shù)據(jù)之類的其他處理,我們需要通過(guò)clone(ture)傳遞一個(gè)布爾值ture用來(lái)指定,這樣不僅僅只是克隆單純的節(jié)點(diǎn)結(jié)構(gòu),還要把附帶的事件與數(shù)據(jù)給一并克隆了。

語(yǔ)法

$(selector).clone(true|false)

參數(shù):


  • true    規(guī)定需復(fù)制事件處理程序。

  • false    默認(rèn)。規(guī)定不復(fù)制事件處理程序。

例如:

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è)顏色

  • 通過(guò)傳遞true,將所有綁定在原始元素上的事件處理函數(shù)復(fù)制到克隆元素上

  • clone()方法是jQuery擴(kuò)展的,只能處理通過(guò)jQuery綁定的事件與數(shù)據(jù)

  • 元素?cái)?shù)據(jù)(data)內(nèi)對(duì)象和數(shù)組不會(huì)被復(fù)制,將繼續(xù)被克隆元素和原始元素共享。深復(fù)制的所有數(shù)據(jù),需要手動(dòng)復(fù)制每一個(gè)

<!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>通過(guò)clone克隆元素</h3>
    <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>

以上是jquery中克隆方法是什么的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

標(biāo)題名稱:jquery中克隆方法是什么-創(chuàng)新互聯(lián)
當(dāng)前地址:http://bm7419.com/article4/dssjie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供App設(shè)計(jì)、外貿(mào)建站、標(biāo)簽優(yōu)化、虛擬主機(jī)、電子商務(wù)網(wǎng)站設(shè)計(jì)公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

綿陽(yáng)服務(wù)器托管