ES6之rest参数、扩展运算符

简介: 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);

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>


总结

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

相关文章
|
前端开发 JavaScript Java
现代化软件开发中的前后端分离模式
随着互联网技术的快速发展,现代化软件开发中的前后端分离模式逐渐成为主流。本文将介绍前后端分离的概念和优势,以及如何在不同的技术栈中实现这种模式。通过前后端分离,可以提高开发效率、降低耦合性,并且更好地满足用户需求。
608 0
|
iOS开发 开发者
苹果iOS App Store上架操作流程详解:从开发者账号到应用发布
很多开发者在开发完iOS APP、进行内测后,下一步就面临上架App Store,不过也有很多同学对APP上架App Store的流程不太了解,下面我们来说一下iOS APP上架App Store的具体流程,如有未涉及到的部分,大家可以及时咨询,共同探讨。
rtsp推流
rtsp推流
823 0
|
存储 缓存 调度
虚拟存储
虚拟存储
693 0
Pandoc——使用ZIP方式安装
Pandoc——使用ZIP方式安装
302 0
|
Web App开发 数据安全/隐私保护
discuz密码找回:忘记管理员密码,忘记UCENTER创始人密码
discuz密码找回:忘记管理员密码,忘记UCENTER创始人密码
1132 1
Vue3 antdv 如何动态渲染 icons-vue 图标(a-icon 不支持了)
Vue3 antdv 如何动态渲染 icons-vue 图标(a-icon 不支持了)
758 0
|
存储 安全 网络安全
Windows操作系统中:共享文件夹以及防火墙介绍
Windows操作系统中:共享文件夹以及防火墙介绍
1096 0
|
运维 算法 数据挖掘
【数据挖掘】离群点检测方法详解及Sklearn中异常检测方法实战(附源码 超详细)
【数据挖掘】离群点检测方法详解及Sklearn中异常检测方法实战(附源码 超详细)
615 0
【数据挖掘】离群点检测方法详解及Sklearn中异常检测方法实战(附源码 超详细)