ES6之rest参数、扩展运算符

embedded/2024/9/23 21:21:32/
文章目录
  • 前言
  • 一、rest参数
  • 二、扩展运算符
    • 1.将数组转化为逗号分隔的参数序列
    • 2.应用
  • 总结


前言

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><div>1</div><div>2</div><div>3</div><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`。

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

   - 在函数调用时,可以使用扩展运算符将数组中的元素作为参数传递给函数。
   - 在数组字面量中,可以使用扩展运算符将一个数组中的元素插入到另一个数组中。
   - 在对象字面量中,可以使用扩展运算符将一个对象中的属性插入到另一个对象中。

   示例:
   ```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参数和扩展运算符的讲解。


http://www.ppmy.cn/embedded/26107.html

相关文章

Nginx从入门到精通

第一章> 1、概述 2、正反向代理 3、负载均衡 4、Nginx安装 第二章> 5、常用命令 6、实战总结 7、前端部署 ***************************************…

cartographer问题处理

问题1 : CMake Error: The following variables are used in this project, but they are set to NOTFOUND. Please set them or make sure they are set and tested correctly in the CMake files: GMOCK_LIBRARY (ADVANCED)linked by target "time_conversion_test&quo…

Android Studio的settings.gradle配置

pluginManagement { repositories { maven { url ‘https://maven.aliyun.com/nexus/content/groups/public/’} maven { url ‘https://maven.aliyun.com/nexus/content/repositories/gradle-plugin’} maven { url ‘https://maven.aliyun.com/nexus/content/repositories/ap…

Rust中的并发性:Sync 和 Send Traits

在并发的世界中&#xff0c;最常见的并发安全问题就是数据竞争&#xff0c;也就是两个线程同时对一个变量进行读写操作。但当你在 Safe Rust 中写出有数据竞争的代码时&#xff0c;编译器会直接拒绝编译。那么它是靠什么魔法做到的呢&#xff1f; 这就不得不谈 Send 和 Sync 这…

Flutter笔记:Widgets Easier组件库(3)使用按钮组件

Flutter笔记 Widgets Easier组件库&#xff08;3&#xff09;&#xff1a;使用按钮组件 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite&#xff1a;http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddre…

头歌:Spark案例剖析 - 谷歌网页排名引擎PageRank实战

第1关:海量数据导入:SparkSQL大数据导入处理 任务描述 工欲善其事必先利其器,大数据分析中最重要的是熟练掌握数据导入工具的使用方法。Spark SQL是Spark自带的数据库,本关你将应用Spark SQL的数据导入工具实现文本数据的导入。其中,graphx-wiki-vertices.txt文件中含有网…

Docker数据管理和Dockerfile

目录 一.数据管理 1.作用 &#xff08;1&#xff09;修改配置文件例如&#xff0c;nginx.conf /usr/local/nginx/conf/nginx.conf —>/container_nginx/conf/nginx.conf &#xff08;2&#xff09;容器内部产生的日志&#xff0c;如何收集将容器内部存方日志文件的目录挂…

C语言【动态内存】

1.为什么要有动态内存 我们现在掌握的内存开辟方法有&#xff1a; int val 20;//在栈空间开辟4个字节 char str[10]{0};//在栈空间开辟10个字节的连续的空间但是上述的方式有两个点要注意&#xff1a; 1.空间开辟的大小是固定的 2.数组在申明的时候&#xff0c;一定要指定数…