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

相关推荐
禅思院5 小时前
前端部署“三层漏斗”完全指南:从CI/CD到自动回滚的工程化实战【开题】
前端·架构·前端框架
快乐肚皮6 小时前
深入理解Loop Engineering
前端·后端
半个落月6 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
风骏时光牛马6 小时前
VHDL十大经典基础功能设计实例代码合集
前端
小兔崽子去哪了6 小时前
Vue3 + Pinia 集成 IGV.js 实现 BAM 文件在线浏览
javascript·vue.js·后端
hunterandroid7 小时前
Notification 通知:从基础到渠道适配
前端
孟陬7 小时前
Claude Code 巧思 `Ctrl+S` 暂存键
前端·后端
PedroQue997 小时前
V1.6.1性能优化:高频路径提速与代码精简
前端·uni-app
猩猩程序员7 小时前
将 LiteLLM 迁移到 Rust —— 构建最快、最轻量的 AI Gateway
前端
小月土星7 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试