【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() 函数。

相关推荐
Front思几秒前
如何学习Shopify前端开发?
前端·学习
码云骑士3 分钟前
语音合成演示 - Web Speech API
前端
ZC跨境爬虫4 分钟前
跟着 MDN 学CSS day_50:(传统布局方法与网格系统)
前端·css·ui·tensorflow·媒体
薛先生_0996 分钟前
vue-路由模块封装
前端·javascript·vue.js
薛先生_0997 分钟前
vue-router-link实现导航高亮效果
前端·javascript·vue.js
郑州光合科技余经理9 分钟前
海外版外卖系统源码:支付/地图/多语言核心代码实现
android·java·前端·后端·架构·uni-app·php
古韵20 分钟前
TanStack Query 被高估了?这 5 个场景它真不如 alova
前端
颂love30 分钟前
Vue3基础入门
前端·学习·vue3
风吹夏回30 分钟前
Vue 3 路由使用完全指南
前端·vue.js
创业之路&下一个五年34 分钟前
JS编程范式 \& 面向对象范式
开发语言·前端·javascript