站長資訊網
        最全最豐富的資訊網站

        Javascript如何復制對象

        Javascript復制對象的方法:1、把原來對象的屬性遍歷一遍,賦給一個新的對象;2、將對象變為字符串,然后再變為json對象;3、concat一個空數組;4、通過擴展運算符實現對象的深拷貝;5、通過ES6擴展運算符實現數組的深拷貝。

        Javascript如何復制對象

        本文操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

        js如何復制一個對象?

        方法一:

        把原來對象的屬性遍歷一遍,賦給一個新的對象。

        //深復制對象方法     var cloneObj = function (obj) {       var newObj = {};       if (obj instanceof Array) {           newObj = [];       }       for (var key in obj) {           var val = obj[key];           //newObj[key] = typeof val === 'object' ? arguments.callee(val) : val; //arguments.callee 在哪一個函數中運行,它就代表哪個函數, 一般用在匿名函數中。           newObj[key] = typeof val === 'object' ? cloneObj(val): val;       }       return newObj;   };   //測試     var obj = {a:function(){console.log(this.b.c)},b:{c:1}},//設置一個對象   newObj = cloneObj(obj);//復制對象   newObj.b.c=2;//給新對象賦新值   obj.a();//1,不受影響   newObj.a();//2

        方法二:

        1). 先將對象變為字符串,然后再變為json對象,防止對象的指針指向問題,為深拷貝

        2). undefined 和 function 類型的屬性會被忽略,而 Date 類型的屬性則會被轉換為字符串

        var obj = {a:1,b:2}   var newObj = JSON.parse(JSON.stringify(obj));   newObj.a=3;   console.log(obj);   console.log(newObj);

        方法三:

        針對數組對象的方法,用數組方法concat一個空數組

        var a=[1,2,3];   var b=a;   var c=[].concat(a);   a.push(4);   console.log(b);   console.log(c);

        方法四:

        擴展運算符實現對象的深拷貝

        var obj = {   name: 'FungLeo',   sex: 'man',   old: '18'}var { ...obj2 } = obj obj.old = '22'console.log(obj) console.log(obj2)

        方法五:

        ES6擴展運算符實現數組的深拷貝

        var arr = [1,2,3,4,5]var [ ...arr2 ] = arr arr[2] = 5console.log(arr) console.log(arr2)

        Javascript如何復制對象

        推薦學習:《javascript高級教程

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 国产精品1区2区3区在线播放| 国产精品青青在线观看爽香蕉 | 日韩精品欧美国产在线| 国产久热精品无码激情| 久久精品国产72国产精福利| 亚洲国产精品第一区二区| 国产AV午夜精品一区二区三区| 最新国产乱人伦偷精品免费网站| 久久噜噜久久久精品66| 国产欧美精品一区二区色综合 | 日韩精品无码熟人妻视频| 久久久精品国产Sm最大网站| 91精品国产91久久久久久| 91精品啪在线观看国产| 久久精品国产99久久久香蕉| 久久99国产精品久久| 国产精品午睡沙发系列| 在线精品亚洲| 日韩精品一区二区三区中文字幕| 国产啪亚洲国产精品无码 | 日韩人妻无码精品久久久不卡 | 香蕉国产精品频视| www.亚洲精品| 99精品国产高清一区二区麻豆| 欧洲精品色在线观看| 中文字幕精品视频在线| 亚洲国产一成久久精品国产成人综合| 精品中文高清欧美| 精品亚洲欧美中文字幕在线看| 国产精品免费视频观看拍拍| 91精品国产麻豆国产自产在线| 亚洲精品免费观看| 91精品国产综合久久四虎久久无码一级 | 久久99国产精品尤物| 人人妻人人澡人人爽人人精品97 | 久久久久久夜精品精品免费啦| 久久久久女人精品毛片| 国产午夜精品一区二区三区| 国语自产少妇精品视频| 国产午夜福利精品久久2021| 国产精品免费看久久久|