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

什么是剩余运算符?

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

剩余运算符的特性

  • 剩余运算符只能作为函数的最后一个参数,否则会报错。
  • 剩余运算符通常是一个数组或对象。
  • 函数的 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]
相关推荐
乐闻x1 分钟前
最佳实践:如何在 Vue.js 项目中使用 Jest 进行单元测试
前端·vue.js·单元测试
檀越剑指大厂16 分钟前
【Python系列】异步 Web 服务器
服务器·前端·python
我是Superman丶18 分钟前
【前端】js vue 屏蔽BackSpace键删除键导致页面后退的方法
开发语言·前端·javascript
Hello Dam19 分钟前
基于 Spring Boot 实现图片的服务器本地存储及前端回显
服务器·前端·spring boot
小仓桑21 分钟前
利用 Vue 组合式 API 与 requestAnimationFrame 优化大量元素渲染
前端·javascript·vue.js
Hacker_xingchen21 分钟前
Web 学习笔记 - 网络安全
前端·笔记·学习
天海奈奈22 分钟前
前端应用界面的展示与优化(记录)
前端
多多*43 分钟前
后端并发编程操作简述 Java高并发程序设计 六类并发容器 七种线程池 四种阻塞队列
java·开发语言·前端·数据结构·算法·状态模式
mubeibeinv1 小时前
列表代码思路
前端
过期的H2O21 小时前
【H2O2|全栈】JS进阶知识(十)ES6(6)
开发语言·前端·javascript·ecmascript·es6