一,对象深拷贝的几种方法
1. 使用递归的方式实现深拷贝
function deepClone(obj){
let objClone = Array.isArray(obj) ? [] : {};
if (obj && typeof obj === 'object') {
for(let key in obj){
if (obj[key] && typeof obj[key] === 'object'){
objClone[key] = deepClone(obj[key]);
}else{
objClone[key] = obj[key]
}
}
}
return objClone;
}
2. 通过JSON对象实现深拷贝
注意: 无法实现对象中方法的深拷贝
function deepClone2(obj) {
let _obj = JSON.stringify(obj);
return JSON.parse(_obj);
}
3. 通过Object.assign()拷贝
注意: 当对象只有一级属性为深拷贝;
当对象中有多级属性时,二级属性后就是浅拷贝
4.实现思路:
- 在函数内部定义一个变量,来存储拷贝出来的内容
- 首先判断传进来的参数是否是引用数据类型,不是引用数据类型返回参数(这里面用的是typeof判断)
- 接下来用instanceof判断是数组还是对象,并且将定义的变量赋值为空数组或者空对象
- 接下来对传进来的参数进行枚举,对枚举出来的属性进行判断递归
// 深拷贝
function deepClone(obj) {
if(typeof obj !=="object" || obj == null){
return obj
}
let res
if(obj instanceof Array){
res = []
}else{
res = {}
}
for(key in obj){
if(obj.hasOwnProperty(key)){
res[key] = deepClone(obj[key])
}
}
return res
}
二,数组深拷贝的几种方法
1. concat(arr1, arr2,....)
注意:当数组中的元素均为一维是深拷贝
数组中元素一维以上是值的引用
2. slice(idx1, idx2)
参数可以省略
1)没有参数是拷贝数组
2)只有一个参数是从该位置起到结束拷贝数组元素
3)两个参数,拷贝从起始位置到结束位置的元素(不包含结束位置的元素:含头不含尾)
注意:当数组中的元素均为一维是深拷贝
数组中元素一维以上是值的引用
- 在函数内部定义一个变量,来存储拷贝出来的内容
- 首先判断传进来的参数是否是引用数据类型,不是引用数据类型返回参数(这里面用的是typeof判断)
- 接下来用instanceof判断是数组还是对象,并且将定义的变量赋值为空数组或者空对象
- 接下来对传进来的参数进行枚举,对枚举出来的属性进行判断递归
本资源由随笔博客发布。发布者:五维国度,转载请注明出处:http://blog.suibi.site/archives/4388
本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。