ES6 Object.assign()的用法

简介: ES6 Object.assign()的用法

Object.assign方法用来将源对象(source)的所有可枚举属性,复制到目标对象(target)。它至少需要两个对象作为参数,第一个参数是目标对象,后面的参数都是源对象。

let targetObj1 = { a: 1 };
let sourceObj1 = { b: 1 };
let sourceObj11 = { c: 3 };
Object.assign(targetObj1, sourceObj1, sourceObj11);
console.log(targetObj1);

注:如果目标对象与源对象有同名属性,或多个源对象有同名属性,则后面的属性会覆盖前面的属性。

let targetObj1 = { a: 1, b: 2 };
let sourceObj1 = { b: 1 };
let sourceObj11 = { c: 3 };
Object.assign(targetObj1, sourceObj1, sourceObj11);
console.log(targetObj1);

如果只有一个参数,Object.assign会直接返回该参数。


let targetObj1 = { a: 4 }
Object.assign(targetObj1);
console.log(targetObj1)

如果该参数不是对象,则会先转成对象,然后返回。


console.log(typeof (Object.assign(2)));

由于undefined和null无法转成对象,所以如果它们作为参数,就会报错。

console.log(typeof(Object.assign(null)));
 console.log(typeof(Object.assign(underfind)));

注意,Object.assign可以用来处理数组,但是会把数组视为对象。


Object.assign只拷贝自身属性,不可枚举的属性(enumerable为false)和继承的属性不会被拷贝。


注意:如果非对象参数出现在源对象的位置(即非首参数),那么处理规则有所不同。首先,这些参数都会转成对象,如果无法转成对象,就会跳过。这意味着, 如果undefined和null不在首参数,就不会报错。其他类型的值(即数值、字符串和布尔值)不在首参数,也不会报错。但是,除了字符串会以数组形式,拷贝入目标对象,其他值都不会产生效果。

对于嵌套的对象,Object.assign的处理方法是替换,而不是添加。

目录
相关文章
|
6月前
|
JavaScript 前端开发
【面试题】 JS手写ES6的Object.create方法
【面试题】 JS手写ES6的Object.create方法
|
19天前
Object.defineProperty用法详解,简单易懂!学起来嘎嘎快!
【10月更文挑战第20天】Object.defineProperty用法详解,简单易懂!学起来嘎嘎快!
Object.defineProperty用法详解,简单易懂!学起来嘎嘎快!
|
2月前
ES6中map对象的使用,确实比Object好使哈
ES6中Map对象的使用优势,包括任意类型作为键、直接获取大小、增删查改操作等。Map的键可以是函数、对象、NaN等,支持forEach循环和for...of循环。
30 1
ES6中map对象的使用,确实比Object好使哈
|
6月前
|
SQL Java 关系型数据库
MyBatis的动态SQL之OGNL(Object-Graph Navigation Language)表达式以及各种标签的用法
MyBatis的动态SQL之OGNL(Object-Graph Navigation Language)表达式以及各种标签的用法
109 0
|
6月前
|
前端开发 JavaScript 容器
你知道css中的object-fit的用法吗?
你知道css中的object-fit的用法吗?
157 0
|
Java
JAVA_Object 类的用法
JAVA_Object 类的用法
57 0
|
JavaScript
ES6对String字符串、Array数组、Number数字、Object对象 类型做了哪些升级优化
ES6对String字符串、Array数组、Number数字、Object对象 类型做了哪些升级优化
108 0
玩转ES6(二)-Object.defineProperty和Proxy代理
玩转ES6(二)-Object.defineProperty和Proxy代理
95 0
|
JavaScript 开发者
ES6之Object.assign()用法,Object.assign()到底是浅拷贝还是深拷贝?
ES6之Object.assign()用法,Object.assign()到底是浅拷贝还是深拷贝?
8702 1
|
索引
ES6 —— 新增方法【Object.defineProperty()】
ES6 —— 新增方法【Object.defineProperty()】