【ES6】 JavaScript 中的Object.assign

Object.assign() 是 JavaScript 中的一个方法,它用于复制源对象的所有可枚举属性到目标对象。该方法会返回目标对象。

这是其基本用法:

javascript 复制代码
let target = Object.assign({}, source);

在这个例子中,source 对象的所有可枚举属性都被复制到了 target 对象。

需要注意的是,Object.assign() 是浅复制(shallow copy),意味着如果源对象中的值是一个对象引用,它只是复制了这个引用,而没有复制引用的对象。

例如:

javascript 复制代码
let obj1 = { a: 1 };
let obj2 = { b: 2 };
let obj3 = Object.assign({}, obj1, obj2);
console.log(obj3); // { a: 1, b: 2 }
console.log(obj3 === obj1); // false
console.log(obj3.a === obj1.a); // true

在这个例子中,尽管 obj3 是从 obj1 和 obj2 复制的,但是 obj3.a 和 obj1.a 是同一个引用,指向同一个对象。因此,如果你需要深度复制,可能需要使用其他方法,例如递归复制或使用库如 Lodash 的 _.cloneDeep() 函数。

相关推荐
C_心欲无痕4 分钟前
使用 FNM (Fast Node Manager) 管理多个 Node.js 版本
前端·node.js
爬山算法7 分钟前
Hibernate(44)Hibernate中的fetch join是什么?
前端·python·hibernate
橙序员小站13 分钟前
解密前端包管理工具:npm、Yarn与pnpm的全面对比
前端·npm·node.js
m0_7482546615 分钟前
HTML DOM - 修改 HTML 内容的方法
前端·html
Jinuss15 分钟前
React16与React17+的JSX转换差异
前端·react.js
爱吃香菜i20 分钟前
数据连接开发设计文档
前端·javascript
冴羽22 分钟前
现代 CSS 颜色使用指南
前端·javascript·css
Rrvive23 分钟前
Vue3向全局广播数据变化
javascript·vue.js
cj814023 分钟前
动态表单与静态表单性能比较
前端
han_29 分钟前
为啥 Array.isArray 判断数组最靠谱?
前端·javascript