ES6之rest参数、扩展运算符

文章目录

前言

rest参数与arguments变量相似。ES6引入rest参数代替arguments,获取函数实参。
扩展运算符能将数组转化为参数序列。


一、rest参数

复制代码
		function namelist1() {
            console.log(arguments);
        }

        function namelist2(...args) {
            console.log(args);
        }

        namelist1('张三', '李四', '王五');
        namelist1('张三', '李四', '王五');

由此可看出args也是数组,所以它可以跟数组方法filter,some,map,every等连用。
注意!rest参数必须放在参数最后,如下:

复制代码
	function fn(a, b, ...args) {
            console.log(a);
            console.log(b);
            console.log(args);
        }
        fn(1, 2, 3, 4);

二、扩展运算符

1.将数组转化为逗号分隔的参数序列

代码如下(示例):

复制代码
	 	const namelist = ['张三', '李四', '王五'];

        function fn() {
            console.log(arguments);
        }
        fn(...namelist); //相当于fn('张三', '李四', '王五')
        console.log(namelist);
        console.log(...namelist);
  • 1

2.应用

  • 数组合并

    复制代码
       	const film = ['失孤', '心灵旅途'];
          const tv = ['盗墓笔记', '秦岭神树'];
          const yule = [...film, ...tv];
          console.log(yule);
  • 数组的克隆

    复制代码
      	const list1 = ['a', 'b', 'c'];
          const list2 = [...list1];
          console.log(list1);
          console.log(list2);
  • 将伪数组转换为真数组

    复制代码
      <!DOCTYPE html>
    <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body>
    1
    2
    3
    <script> const divs = document.querySelectorAll('div'); const divlist = [...divs]; console.log(divs); console.log(divlist); </script> </body> </html>

ES6 引入了 rest 参数和扩展运算符,它们提供了更便捷的方式来处理函数参数和数组操作。

Rest 参数允许将不定数量的参数表示为一个数组。在函数声明时,在最后一个命名参数之前使用三个点(...)即可表示 rest 参数。这个参数将接收传入函数的所有剩余参数,并将它们作为一个数组存储起来。

示例:

```javascript

function sum(...args) {

return args.reduce((acc, val) => acc + val, 0);

}

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

console.log(sum(1, 2, 3, 4, 5)); // 输出 15

```

在这个示例中,`...args` 将接收传入的所有参数,并将它们存储为一个数组 `args`。

  1. **扩展运算符**:

扩展运算符允许将数组展开,作为函数的参数,或者用于数组字面量和对象字面量中。

  • 在函数调用时,可以使用扩展运算符将数组中的元素作为参数传递给函数。

  • 在数组字面量中,可以使用扩展运算符将一个数组中的元素插入到另一个数组中。

  • 在对象字面量中,可以使用扩展运算符将一个对象中的属性插入到另一个对象中。

示例:

```javascript

// 函数调用时使用扩展运算符

function multiply(x, y, z) {

return x * y * z;

}

const numbers = [1, 2, 3];

console.log(multiply(...numbers)); // 输出 6

// 数组字面量中使用扩展运算符

const arr1 = [1, 2, 3];

const arr2 = [...arr1, 4, 5, 6];

console.log(arr2); // 输出 [1, 2, 3, 4, 5, 6]

// 对象字面量中使用扩展运算符

const obj1 = { a: 1, b: 2 };

const obj2 = { ...obj1, c: 3, d: 4 };

console.log(obj2); // 输出 { a: 1, b: 2, c: 3, d: 4 }

```

在这些示例中,`...` 符号用于展开数组或对象,使其能够在函数参数、数组字面量或对象字面量中以更灵活的方式使用。

总结

以上就是rest参数和扩展运算符的讲解。

相关推荐
Z兽兽1 天前
React@18+Vite项目配置env文件
前端·react.js·前端框架
SuniaWang1 天前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
A_nanda1 天前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06261 天前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~1 天前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
LegendNoTitle1 天前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界1 天前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
BJ-Giser1 天前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码20351 天前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
发现一只大呆瓜1 天前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite