1. js浅拷贝只是创建了一个新的对象,复制了原有对象的基本类型的值。
const shallowCopy = (target) => {
return Object.assign({}, target)
}
const shallowCopy1 = (target) => {
return {...target}
}
手写实现
const shllowClone = (target) => { // 创建新对象 const cloneObj = Array.isArray(target) ? [] : {} for (let key in target) { // 如果属性是原对象的直接属性(不是继承的属性),则将它赋值给新对象 if (target.hasOwnProperty(key)) { cloneObj[key] = target[key] } } return cloneObj }
2. 深拷贝的原理和实现文章来源:https://www.toymoban.com/news/detail-800242.html
将一个对象从内存中完整地拷贝出来一份给目标对象,并从堆内存中开辟一个全新的空间存放新的对象,且新对象的修改并不会改变原对象,二者实现真正的分离文章来源地址https://www.toymoban.com/news/detail-800242.html
到了这里,关于JavaScript深浅拷贝的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!