在ES6中在对象的原型的有一个assign方法,可以实现对象的克隆,但克隆是浅克隆,主要表现在对象的第二层如果含有对象,则第二层的对象还是引用原有的对象,有时候并不能达到我们的预期。而比较简单的一种方法实现深克隆则是利用JSON对象把对象字符化,然后再解释回对象,这种方法是最简洁的方法,但是如果对象里含有方法则把方法给过滤掉了。为了避免以上的两种实现方法的功能上的缺陷,我封装了一个深克隆的方法,代码贴下面:
function clone(o) {
let res = {}
if(o instanceof Array) {
res = o.map(i => clone(i))
}else {
let keys = Object.keys(o)
keys.forEach(i => {
if(typeof o[i] === 'object' && o[i]) {
res[i] = clone(o[i])
}else{
res[i] = o[i]
}
})
}
return res
}
使用时注意,代码使用到ES6语法。