深拷贝

改变原数组的方法

pop():删除数组最后一个元素,并返回该元素
push():在数组尾部添加元素,并返回更新后的数组长度
shift():删除数组的第一个元素,并返回该元素
unshift():在数组第一位添加元素,并返回更新后的数组长度
sort():对数组排序(按字符ASCII进行排序),也可添加回调函数按照想要的规则排序
reverse():数组反转
splice(index, howmany, 新数据):返回被删除元素所组成的数组。

var a = [1, 2, 3];
// 此时需要b等于a,但是改变b时,不影响a

//方法一,slice()
var b1 = a.slice();

//方法二,concat()
var b2 = [].concat(a);

//方法三,JSON.parse(JSON.stringify())
var b3 = JSON.parse(JSON.stringify(a));

//方法四,手写深拷贝方法
var deepCopy = function(obj) {
  if (typeof obj !== 'object') return;
  var newObj = obj instanceof Array ? [] : {};
  for (var key in obj) {
    if (obj.hasOwnProperty(key)) {
      newObj[key] = typeof obj[key] === 'object' ? deepCopy(obj[key]) : obj[key];
    }
  }
  return newObj;
}
var b4 = deepCopy(a);

对象的深拷贝

var obj = {
                name:'zs',
                age:12,
                dog:{
                    name:'jm',
                    age:2
                },
                friends:['ls','dd']
            }
function deep(o1,o2){
                for(var key in o1){
                    var item = o1[key];
                        if(item instanceof Object){
                            var o = {}
                            deep(item,o)
                        }else if(item instanceof Array){
                            var arr=[]
                            deep(item,arr)
                        }           
                    o2[key] = o1[key]
                }
            }
            var obj2={}
            deep(obj,obj2)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。