欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解jQuery的拷貝對象

 更新時(shí)間:2021年11月22日 11:40:44   作者:知秋之  
這篇文章主要為大家介紹了jQuery的拷貝對象,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="jquery.min.js"></script>
    <script>
        $(function() {
            //1, 普通拷貝,默認(rèn)為淺拷貝
            var targetObj = {};
            var obj = {
                id: 1,
                name: "andy"
            };
            $.extend(targetObj, obj); //拷貝語法,把obj內(nèi)的屬性和屬性值拷貝給targetObj一個(gè)空對象
            console.log(targetObj); //輸出結(jié)果是 obj對象里面的內(nèi)容
            //2. 拷貝對象里面有屬性和屬性值情況下
            var targett = {
                id: 0,
                gshg: 55
            };
            var objrr = {
                id: 1,
                name: "andy"
            };
            $.extend(targett, objrr);
            console.log(targett); // 如果拷貝對象targett里面屬性和被拷貝對象objrr里面屬性有相同的,則objrr里面屬性值會(huì)覆蓋掉targett里面屬性值
            //如果拷貝對象targett里面有屬性與被拷貝對象objrr里面屬性名不相同的不會(huì)被覆蓋,被拷貝對象objrr里面屬性只會(huì)后來居上
            //3. 拷貝對象里面有對象情況下,淺拷貝
            var taytuj = {
                id: 0,
                msg: {
                    sex: '男'
                }
            };
            var rete = {
                id: 1,
                name: "andy",
                msg: {
                    age: 18
                }
            };
            $.extend(true, taytuj, rete);
            console.log(taytuj);
            // 執(zhí)行過程:
            //1.兩個(gè)對象都在內(nèi)存棧中,其中rete對象里面的 msg: {  age: 18  }對象放在了內(nèi)存堆中,在淺拷貝中,rete對象里面的 msg: {  age: 18  }會(huì)覆蓋掉taytu對象的msg: {sex: '男' },屬性值會(huì)變成一個(gè)16進(jìn)制指向內(nèi)存堆中的msg: {  age: 18  }對象,此時(shí)??臻g中兩個(gè)對象的 msg里面都有同一個(gè)執(zhí)向內(nèi)存堆中msg: {  age: 18  }的16進(jìn)制地址,所以如果淺拷貝完成后,兩個(gè)對象里面msg屬性值只要一個(gè)發(fā)生了改變,另外一個(gè)msg的屬性值也會(huì)隨著一起改變
            //淺拷貝:
            //1.屬性名相同的,被拷貝對象會(huì)覆蓋掉拷貝對象,排序永遠(yuǎn)是后來居上
            //2. 屬性名不相同的則合并
            //深拷貝:
            //1.屬性名相同的,被拷貝對象的屬性和屬性值會(huì)覆蓋掉拷貝對象的屬性和屬性值,排序永遠(yuǎn)是后來居上
            //2. 屬性名不相同的則合并
            //3.拷貝對象和拷貝對象里面有對象的,如果對象名相同,屬性名不同,則會(huì)合并,并不是覆蓋。
        })
    </script>
</head>
<body>
</body>
</html>

總結(jié)

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

最新評論