方法Object.assign()
作用:将sourse对象的 赋值给目标对象,两者都有的会覆盖,target独有会保留,sourse独有会添加
使用方法
1.复制对象

var obj = { a: 1 };
var copy = Object.assign({}, obj);
console.log(copy); // { a: 1 }

2.合并对象

var o1 = { a: 1 };
var o2 = { b: 2 };
var o3 = { c: 3 };var obj = Object.assign(o1, o2, o3);
console.log(obj); // { a: 1, b: 2, c: 3 }
console.log(o1);  // { a: 1, b: 2, c: 3 }, 注意目标对象自身也会改变。

3.合并具有相同属性的对象

var o1 = { a: 1, b: 1, c: 1 };
var o2 = { b: 2, c: 2 };
var o3 = { c: 3 };var obj = Object.assign({}, o1, o2, o3);
console.log(obj); // { a: 1, b: 2, c: 3 }

需要避免的问题:针对深拷贝,需要使用其他方法,因为 Object.assign()拷贝的是属性值,假如源对象的属性值是一个指向对象的引用,它也只拷贝那个引用值

JS中 Object.assign()用法相关推荐

  1. ES6之Object.assign()用法,Object.assign()到底是浅拷贝还是深拷贝?

    基本用法 Object.assign方法用于对象的合并,将源对象(source)的所有可枚举属性,复制到目标对象(target). const target = { a: 1 }; const sou ...

  2. JS中typeof的用法

    转载自  JS中typeof的用法 js是一门弱语言,它在声明变量时无需确定变量的类型,js在运行时会自动判断.那么如何判断一个变量的类型呢,js提供了typeof运算符,用来检测一个变量的类型. 1 ...

  3. Object.assign()用法讲解

    Object.assign()用法讲解 语法: Object.assign(target, -sources) target: 目标对象,sources: 源对象 用于将所有可枚举属性的值从一个或多个 ...

  4. JS中reduce的用法

    JS中reduce的用法 前言 语法 举例 reduce的应用 总结 前言 reduce() 方法对数组中的每个元素执行一个由您提供的reduce函数(升序执行),将其结果汇总为单个返回值.reduc ...

  5. php function函数用法,js的function函数是什么?js中function的用法

    本篇文章给大家带来的内容是关于js的function函数是什么?js中function的用法,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. Function与函数 Function是 ...

  6. append和appendTo的区别以及js中的appendChild用法

    append和appendTo的区别以及js中的appendChild用法 很多像我一样接触JS没多久的小白对append和appendTo的区别以及js中的appendChild用法都会有所模糊,下 ...

  7. js中indexOf的用法详解

    js中indexOf的用法详解 String.IndexOf 方法 (Char, [startIndex], [count]) 报告指定字符在此实例中的第一个匹配项的索引.搜索从指定字符位置开始,并检 ...

  8. js控制页面滚动到指定位置,js中scrollIntoView()的用法

    js中scrillIntoView()的用法--页面滚动到指定位置 最近遇到一个问题,在一个页面上,点击某个按钮时,滚动到页面的某一位置. 如图: 如果是我写的话,我可能会先获取滚动到的元素,然后获取 ...

  9. js中return的用法

    js中return的用法 今天看到一篇文章,介绍的是js中return的用法,感触很深.(类似于JAVA return) 在大多数情况下,为事件处理函数返回false,可以防止默认的事件行为.例如,默 ...

最新文章

  1. Openfire XMPP Smack RTC IM 即时通讯 聊天 MD
  2. mysql1033错误存储引擎_【Mysql问题集锦(1)】mysql不能使用innodb存储引擎
  3. 【Python】【函数式编程】
  4. 在敏捷中应用测试驱动开发
  5. 蚂蚁借呗和京东金条全面对比,哪个更划算?
  6. 浏览器插件:一款解决谷歌浏览器吃内存神器插件,你值得试一试!
  7. Linux用户管理详解大结局(下)
  8. R语言学习笔记(八)判别分析
  9. mysql 提示ssl问题
  10. MySQL的show profile(已过时)简介以及该功能在MySQL 5.7中performance_schema中的替代
  11. cocoaPods:公有库私有库
  12. sql中 replace函数
  13. Linux密码忘了怎么办!
  14. 初写数学建模论文 -- 摸鱼1
  15. 嵌入式系统开发环境的构建08:在Hyper-V中安装Windows XP操作系统
  16. element ui实现抽屉效果_如何给element添加一个抽屉组件
  17. 软件测试之因果图分析法
  18. 水哥 liunx之旅之输入法
  19. 前端找实习岗的7条建议
  20. appbase_实时图形数据库即服务与Appbase

热门文章

  1. 机器视觉汽车配件检测流程介绍
  2. 3孔融分梨 4分 函数c语言,孔融分梨有绝招
  3. PairProject 总结
  4. (一)Redis常用数据类型及应用场景(Redis的解决方案汇总)
  5. 【论文笔记】投影仪-相机系统标定方法
  6. Windows 安装dbserver
  7. ATmega8 定时器 中断 外部中断 程序
  8. GSMA移动360会议首次亮相马来西亚
  9. 使用软碟通软件制作U盘启动盘
  10. nginx搭建图片服务器