ES6...扩展操作符骚操作

复制和合并数组变得更为简洁。不需要使用 concat() 方法或 slice() 方法,一个 ... 操作符已经足够:

js 复制代码
    const arr1 = [10, 20, 30];

    const copy = [...arr1];

    console.log(copy);    // → [10, 20, 30]

    const arr2 = [40, 50];

    const merge = [...arr1, ...arr2];

    console.log(merge);    // → [10, 20, 30, 40, 50]

将数组作为一个需要单独一个个传入参数的函数的参数

js 复制代码
    const arr = [10, 20, 30]

    // equivalent to
    // console.log(Math.max(10, 20, 30));
    console.log(Math.max(...arr));    // → 30

对象属性展开复制

js 复制代码
    const obj1 = {
      a: 10,
      b: 20
    };

    const obj2 = {
      ...obj1,
      c: 30
    };

    console.log(obj2);    // → {a: 10, b: 20, c: 30}

如果存在相同的值 后者覆盖前者

js 复制代码
    const obj2 = {
      ...obj1,
      a: 30
    };

    console.log(obj2);    // → {a: 30, b: 20}

合并对象 类似于object.assign

js 复制代码
    const obj1 = {a: 10};
    const obj2 = {b: 20};
    const obj3 = {c: 30};

    // ES2018
    console.log({...obj1, ...obj2, ...obj3});    // → {a: 10, b: 20, c: 30}

    // ES2015
    console.log(Object.assign({}, obj1, obj2, obj3));    // → {a: 10, b: 20, c: 30}

不过,扩展属性并不总能生成与 Object.assign() 相同的结果 具体自己去试验下 要点 == setter

相关推荐
程序员Sunday6 分钟前
爆肝万字!这应该是全网最全的 Codex 实战教程了
前端·后端·ai编程
aircrushin7 分钟前
朋友用trae搭建的工具,解决了旅行拍照共享的大事儿
前端·后端
ZC跨境爬虫13 分钟前
跟着 MDN 学 HTML day_41:(DOMParser 接口详解)
前端·javascript·ui·html·音视频
threelab20 分钟前
Three.js 概率统计可视化 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能
光影少年26 分钟前
useLayoutEffect 和 useEffect 区别、使用场景
开发语言·前端·javascript
LIO37 分钟前
掌握 React useEffect:核心概念、使用技巧与常见陷阱
前端·react.js
XD74297163641 分钟前
科技早报晚报|2026年5月12日:GUI Agent、编程会话工作台与 npm 安装门禁,今晚更值得做的 3 个技术机会
前端·科技·npm·供应链安全·ai agent·开发者工具
下雨打伞干嘛43 分钟前
redux的使用
开发语言·javascript·ecmascript
前端那点事1 小时前
Vue3 新趋势:10个高阶实用操作|性能优化+开发提效+避坑指南
前端·vue.js
small_white_robot1 小时前
idek-2022 web 全wp——持续更新
开发语言·前端·javascript·网络·安全·web安全·网络安全