一篇文章帮你彻底搞懂剩余运算符!!

什么是剩余运算符?

剩余参数也是一种操作符,它用于表示数组中的不定数量的参数。常用于将逗号隔开的值序列组合成一个数组或对象。它在语法层面将多个值组合成一个集合。

剩余运算符的特性

  • 剩余运算符只能作为函数的最后一个参数,否则会报错。
  • 剩余运算符通常是一个数组或对象。
  • 函数的 length 属性不包括剩余参数。
  • 我们可以用剩余运算符替代了 arguments 对象。
  • 使用了剩余运算符的函数内部不能显式的设置严格模式,否则会报错。

结合代码进行说明

剩余运算符之后不能再有其他参数

错误用法

js 复制代码
1.  function foo(a, ...b, c) {
  // ...
  }
//编辑器会报错, SyntaxError: Rest parameter must be last formal paramet
js 复制代码
const order = function(beverage, ...otherIngredients) {
  console.log(beverage);
  console.log(otherIngredients);
};

order('green tea', 'milk', 'brown sugar', 'mint', 'tonka'); 
// output:
// green tea 
// ['milk', 'brown sugar', 'mint', 'tonka']

剩余运算符通常是一个数组或对象。

scss 复制代码
   function foo(...values) {  
       console.log(values);
  }

  foo(2, 5, 3) //  [2, 5, 3]

函数的 length 属性不包括剩余参数。

js 复制代码
1.  (function(...a) {}).length // 0
1.  (function(a, ...b) {}).length // 1

剩余运算符替代 arguments 对象。

js 复制代码
// 使用剩余运算符获取参数列表并计算它们的总和
function sum(...numbers) {
    let total = 0;
    for (let num of numbers) {
        total += num;
    }
    return total;
}

// 使用arguments对象获取参数列表并计算它们的总和(已被剩余运算符取代)
function sumWithArguments() {
    let total = 0;
    for (let i = 0; i < arguments.length; i++) {
        total += arguments[i];
    }
    return total;
}

// 测试
console.log(sum(1, 2, 3)); // 输出 6
console.log(sumWithArguments(1, 2, 3)); // 输出 6

使用了 rest 参数的函数内部不能显示设定严格模式,否则会报错

js 复制代码
    // 报错
  const doSomething = (...a) => {
  'use strict';
  // code

通过剩余运算符来进行解构

ini 复制代码
const [a, b, ...others] = [1, 2, 3, 4, 5];
console.log(a, b, others); 
// output: 1 2 [3, 4, 5]
相关推荐
逆光如雪3 分钟前
控制台快速查看自己的log,提高开发效率
前端
用户47949283569153 分钟前
年薪百万的 React 功底怎么“装进”AI?Vercel 的这个 Skill 给了标准答案
前端·aigc·ai编程
jason_yang4 分钟前
这5年在掘金的感想
前端·javascript·vue.js
一人の梅雨4 分钟前
亚马逊SP-API商品评论接口实战:情感分析+商业洞察挖掘的差异化方案
运维·前端·数据库
掘金一周7 分钟前
Dart 官方再解释为什么放弃了宏编程,并转向优化 build_runner ?| 掘金一周 1.15
前端
魔术师卡颂20 分钟前
提问量暴跌 80% ,Stack Overflow 却赚翻了?
前端·后端·ai编程
rocky19120 分钟前
什么,你还没用 claude,out 了吧!
前端·程序员
Younglina36 分钟前
想提升专注力?我做了一个web端的训练工具
前端·vue.js·游戏
NEXT061 小时前
CSS 选择器深度实战:从“个十百千”权重法到零 DOM 动画的降维打击
前端·css
Mapmost1 小时前
防患未“燃”:掌握森林火灾仿真分析,精准把控火势蔓延趋势
前端