当前位置:网站首页>Object.assign用法 以及 与$.extend的区别
Object.assign用法 以及 与$.extend的区别
2022-08-10 20:52:00 【菜鸟小窝】
一、概述
我们先看看ES6官方文档是怎么介绍的?
Object.assign()方法用于将所有可枚举属性的值从一个或多个源对象复制到目标对象。它将返回目标对象。简单来说,就是
Object.assign()是对象的静态方法,可以用来复制对象的可枚举属性到目标对象,利用这个特性可以实现对象属性的合并。
二、用法
Object.assign(target, ...sources)
参数: target--->目标对象
source--->源对象
返回值:target,即目标对象
三、使用示例
1、目标对象和源对象无重名属性
var target={
name:'guxin',age:18};
var source={
state:'single'}
var result=Object.assign(target,source);
console.log(target,target==result);
结果:
{name: 'guxin', age: 18, state: 'single'} true
var result=Object.assign({
},target,source);
2、目标对象和源对象有重名属性
如果有同名属性的话,后面的属性值会覆盖前面的属性值。
var target={
name:'guxin',age:18}
var source={
state:'signle',age:22}
var result=Object.assign(target,source)
console.log(target)
运行结果:
{name: 'guxin', age: 22, state: 'signle'}
3、有多个源对象
有多个源对象情况也是和一个源对象一样的。
没有同名的属性会直接复制到目标对象上,同名的属性后面的属性值会覆盖前面的同名属性值。
var target={
name:'guxin',age:18}
var source1={
state:'signle',age:22}
var source2={
mood:'happy',age:25}
var result=Object.assign(target,source1,source2)
console.log(target)
运行结果:
{name: 'guxin', age: 25, state: 'signle', mood: 'happy'}
四、注意事项:
Object.assign方法只会拷贝源对象自身的并且可枚举的属性到目标对象,继承属性和不可枚举属性是不能拷贝的。针对深拷贝,需要使用其他办法,因为
Object.assign()拷贝的是属性值。假如源对象的属性值是一个对象的引用,那么它也只指向那个引用。目标对象自身也会改变
异常会打断后续拷贝任务
五、兼容性
目前IE浏览器不兼容Object.assign(),如果需要兼容IE的话最好不要直接使用这个方法。
解决方法如下:
1、添加方法
使用以下方式进行添加
if(typeof Object.assign != 'function') {
(function() {
Object.assign = function(target) {
'use strict';
if(target === undefined || target === null) {
throw new TypeError('Cannot convert undefined or null to object');
}
var output = Object(target);
for(var index = 1; index < arguments.length; index++) {
var source = arguments[index];
if(source !== undefined && source !== null) {
for(var nextKey in source) {
if(source.hasOwnProperty(nextKey)) {
output[nextKey] = source[nextKey];
}
}
}
}
return output;
};
})();
}
2、替换方法
使用 $.extend() 替换 Object.assign() 。
六、与$.extend()的比较
1、相同点
- 函数用于将一个或多个对象的内容合并到目标对象。
- 都可以用于浅拷贝
$.extend(target ,defaults, options) 与Object.assign(target ,defaults, options)
2、不同点
$.extend(true, target ,defaults, options) 可用于深拷贝。
$.extend(true,{
},a,b)
- true:是否深度拷贝,不加为false,浅拷贝,加了深拷贝
- {}:将合并结果保存到新对象,这样原对象将不会发生改变
- a:第一个合并的对象
- b:第二个合并的对象
边栏推荐
- 2021年中国工业互联网安全大赛(福建省选拔赛) 暨首届福建省工业互联网创新大赛
- LeetCode questions 1-10
- 【golang map】 深入了解map内部存储协议
- DDL:视图——《mysql 从入门到内卷再到入土》
- 如何提高代码的可读性 学习笔记
- npm warn config global `--global`, `--local` are deprecated. use `--location=global` instead.
- PostgreSQL — 安装及常用命令
- npm WARN config global `--global`, `--local` are deprecated. Use `--location=global` instead.
- 单选点击可取消功能
- 2021DozerCTF
猜你喜欢
随机推荐
SELECT:简单的查询操作语法&使用例——《mysql 从入门到内卷再到入土》
自建函数 测试例和语法——《mysql 从入门到内卷再到入土》
DDL:CREATE 创建数据库——《mysql 从入门到内卷再到入土》
The use of TortoiseSVN little turtle
A fullGC problem troubleshooting caused by groovy
Kubernetes 笔记 / 入门 / 生产环境 / 用部署工具安装 Kubernetes / 用 kubeadm 启动集群 / 用 kubeadm 创建集群
化学制品制造业数智化供应链管理系统:建立端到端供应链采购一体化平台
C 语言 时间函数使用技巧(汇总)
B. Codeforces Subsequences
【CMU博士论文】视频多模态学习:探索模型和任务复杂性,152页pdf
石油化工行业商业供应链管理系统:标准化供应商管理,优化企业供应链采购流程
wget编译升级故障解决
这些mysql基础命令、基础知识还记得吗?(面试,学习,复习都可以)一万三千字总结
How to submit a PR?【OpenHarmony Growth Plan】【OpenHarmony Open Source Community】
Detailed explanation and use of each module of ansible
找的笔试题的复盘(一)
Rider调试ASP.NET Core时报thread not gc-safe的解决方法
C. Rotation Matching
ACM解题笔记——HDU 1401 Solitaire(DBFS)
B. Same Parity Summands






![[mysql] 深入分析MySQL版本控制MVCC规则](/img/16/e28641c355d941fda50a6e8b7911ee.png)

