- A+
所属分类:Web前端
//模拟对象 let obj = { numberParams:1, functionParams:() => { console.log('昨天基金全是绿的,只有我的眼睛是红的'); }, objParams:{ a:1, b:2 } } const newObj = copyObj(obj); //这样就完成了一个对象的递归拷贝 obj.numberParams = 100; //更改第一个对象的指 console.log(newObj.numberParams); //输出依然是1 不会跟随obj去改变
//函数拷贝
const copyObj = (obj = {}) => {
//变量先置空
let newobj = null;
//判断是否需要继续进行递归
if (typeof (obj) == 'object' && obj !== null) {
newobj = obj instanceof Array ? [] : {};
//进行下一层递归克隆
for (var i in obj) {
newobj[i] = copyObj(obj[i])
}
//如果不是对象直接赋值
} else newobj = obj;
return newobj;
}
作者: 阿清
链接: https://aqingya.cn/articl/80b561a9.html
来源: 阿清的小站
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数凑字数