es6之扩展运算符 三个点(...)

  • es6之扩展运算符 三个点(...)
    • 对象的扩展运算符
    • 数组的扩展运算符
    • 总结

      数组的扩展运算符
      扩展运算符同样可以运用在对数组的操作中。

      可以将数组转换为参数序列
      function add(x, y) {
      return x + y;
      }

      const numbers = [4, 38];
      add(...numbers) // 42

      可以复制数组
      如果直接通过下列的方式进行数组复制是不可取的:

      const arr1 = [1, 2];
      const arr2 = arr1;
      arr2[0] = 2;
      arr1 // [2, 2]

      原因上面已经介绍过,用扩展运算符就很方便:

      const arr1 = [1, 2];
      const arr2 = [...arr1];

      还是记住那句话:扩展运算符(…)用于取出参数对象中的所有可遍历属性,拷贝到当前对象之中,这里参数对象是个数组,数组里面的所有对象都是基础数据类型,将所有基础数据类型重新拷贝到新的数组中。

      扩展运算符可以与解构赋值结合起来,用于生成数组
      const [first, ...rest] = [1, 2, 3, 4, 5];
      first // 1
      rest // [2, 3, 4, 5]

      需要注意的一点是:

      如果将扩展运算符用于数组赋值,只能放在参数的最后一位,否则会报错。

      const [...rest, last] = [1, 2, 3, 4, 5];
      // 报错
      const [first, ...rest, last] = [1, 2, 3, 4, 5];
      // 报错

      扩展运算符还可以将字符串转为真正的数组
      [...'hello']
      // [ "h", "e", "l", "l", "o" ]

      任何 Iterator 接口的对象(参阅 Iterator 一章),都可以用扩展运算符转为真正的数组
      这点说的比较官方,大家具体可以参考阮一峰老师的ECMAScript 6入门教程。

      比较常见的应用是可以将某些数据结构转为数组,比如:

      // arguments对象
      function foo() {
      const args = [...arguments];
      }

      用于替换es5中的Array.prototype.slice.call(arguments)写法。

      总结
      扩展运算符的用法就说到这里,介绍的不全但都是些最常见的用法。

       

posted @   20211103  阅读(55)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类
点击右上角即可分享
微信分享提示