Javascrip深浅克隆

克隆

提前应该知道的知识:基本类型值和引用类型值

  1. 基本类型值:数字,字符串,布尔,undefined等
    var a = b进行传值时,内存中会产生新的副本,用==时会比较值是否相等

  2. 引用类型值:对象,数组

    var a = b进行传值时,只是让新的变量指向前一个对象,用==比较时会比较内存地址是否相同

浅克隆

var arr2 = arr1 并不能实现克隆,因为arr1与arr2指向的是同一地址,本质上是相同的。

要实现浅克隆可以用空数组遍历一遍原数组。

注意:浅克隆只能克隆数组的一层,如果克隆的数组为多维数组,则会“藕断丝连”。push时会出现两个数组用等号相连的情况

var arr_1 = [11, 22, 33, 44, [55, 66]];
var arr = [];
for(i = 0; i < arr_1.length; i++){
	arr.push(arr_1[i])
	}
console.log(arr);        //[11, 22, 33, 44, [55, 66]]
console.log(arr_1 == arr);      //false
arr_1[4].push(77);    //给原数组的二维项push新的数据
console.log(arr[4]); //[11, 22, 33, 44, [55, 66, 77]]

深克隆

仍然用遍历方法,加用递归,遇到基本类型值则直接push,遇到数组则再次遍历遇到的数组,直到不再遇到数组。

var arr1 = [11, 22, 33, 44, [55, 66]];
function deepClone(arr){
var result = [];
for(var i = 0; i < arr.length; i++){
	if(Array.isArray(arr[i])){
	result.push(deepClone(arr[i]));
	}else{
	result.push(arr[i]);
	}
	}
return result;
}
var arr2 = deepClone(arr1);
console.log(arr2);//[11, 22, 33, 44, [55, 66]]
arr1.push(77);
console.log(arr1);//[11, 22, 33, 44, [55, 66],77]
console.log(arr2);//[11, 22, 33, 44, [55, 66]]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值