var x = 1; var y = x; //y获得了和x同样的值 y = 2; console.log(x); // 1 var m = [1,2]; //m存放的是指向[1,2]这个数组对象的引用地址 var n = m; //n也获得 [1,2]数组对象的引用地址 n[0] = 3; console.log(m); //[3,2]
//测试数据
var array1 = ['a',1,true,{name:'lei',age:18}];
//concat() slice() 实现浅拷贝
var array2 = array1.concat()
//修改拷贝后的数据
array2[0] = 'b'; //array1[0]是原始数据类型 所以是直接赋值的
array2[3].name = 'zhang'; //array1[3]是对象数据类型 所以拷贝的是对象的引用,其实还是和原数组使用同一对象
console.log(array1); // ['a',1,true,{name:'zhang',age:18}]
//实现浅拷贝
function shallowCopy( target ){
if(typeof target !== 'object') return ;
//判断目标类型,来创建返回值
var newObj = target instanceof Array ? [] : {};
for(var item in target){
//只复制元素自身的属性,不复制原型链上的
if(target.hasOwnProperty(item)){
newObj[item] = target[item]
}
}
return newObj
}</strong>
//测试
var test = [1,'a',{name:'lei',age:18}];
var copy = shallowCopy(test);
console.log(copy[2].name); //lei
copy[2].name = 'zhang';
console.log(test[2].name); //zhang 原数据也被修改
var test = [1,'a',{name:'lei',age:18}];
var copy1 = JSON.parse(JSON.stringify(test)); //特殊方式
console.log(copy1);
copy1[2].name = 'zhang'
console.log(test); //[1,'a',{name:'lei',age:18}] 未受到影响
//实现深拷贝
function deepCopy( target ){
if(typeof target !== 'object') return ;
//判断目标类型,来创建返回值
var newObj = target instanceof Array ? [] : {};
for(var item in target){
//只复制元素自身的属性,不复制原型链上的
if(target.hasOwnProperty(item)){
newObj[item] = <strong>typeof target[item] == 'object' ? deepCopy(target[item]) : target[item] //判断属性值类型
</strong> }
}
return newObj
}
//测试
var test = [1,'a',{name:'lei',age:18}];
var copy2 = deepCopy(test);
copy2[2].name = 'zhang'
console.log(test); ////[1,'a',{name:'lei',age:18}] 未受到影响
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有