码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • JavaScript系列之剩余参数


    文章の目录

    • 一、概述
    • 二、语法
    • 三、描述
      • 1、剩余参数和 arguments对象的区别
      • 2、从 arguments 到数组
      • 3、解构剩余参数
    • 四、示例
    • 写在最后


    一、概述

    剩余参数语法允许我们将一个不定数量的参数表示为一个数组。

    二、语法

    function (a, b, ...theArgs) {
    	// ...
    }
    
    • 1
    • 2
    • 3

    三、描述

    如果函数的最后一个命名参数以...为前缀,则它将成为一个由剩余参数组成的真数组,其中从 0(包括)到theArgs.length(排除)的元素由传递给函数的实际参数提供。

    1、剩余参数和 arguments对象的区别

    • 剩余参数只包含那些没有对应形参的实参,而 arguments 对象包含了传给函数的所有实参。
    • arguments对象不是一个真正的数组,而剩余参数是真正的 Array 实例,也就是说你能够在它上面直接使用所有的数组方法,比如 sort,map,forEach或pop。
    • arguments对象还有一些附加的属性 (如callee属性)。

    2、从 arguments 到数组

    引入了剩余参数来减少由参数引起的样板代码。

    // Before rest parameters, "arguments" could be converted to a normal array using:
    
    function f(a, b) {
    	var normalArray = Array.prototype.slice.call(arguments);
    	// -- or --
    	var normalArray = [].slice.call(arguments);
    	// -- or --
    	var normalArray = Array.from(arguments);
    
    	var first = normalArray.shift(); // OK, gives the first argument
    	var first = arguments.shift(); // ERROR (arguments is not a normal array)
    }
    
    // Now we can easily gain access to a normal array using a rest parameter
    
    function f(...args) {
    	var normalArray = args;
    	var first = normalArray.shift(); // OK, gives the first argument
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    3、解构剩余参数

    剩余参数可以被解构,这意味着他们的数据可以被解包到不同的变量中。请参阅解构赋值。

    function f(...[a, b, c]) {
    	return a + b + c;
    }
    
    f(1); // NaN (b and c are undefined)
    f(1, 2, 3); // 6
    f(1, 2, 3, 4); // 6 (the fourth parameter is not destructured)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    四、示例

    因为theArgs是个数组,所以你可以使用length属性得到剩余参数的个数:

    function fun1(...theArgs) {
    	alert(theArgs.length);
    }
    
    fun1(); // 弹出 "0", 因为 theArgs 没有元素
    fun1(5); // 弹出 "1", 因为 theArgs 只有一个元素
    fun1(5, 6, 7); // 弹出 "3", 因为 theArgs 有三个元素
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    写在最后

    如果你感觉文章不咋地//(ㄒoㄒ)//,就在评论处留言,作者继续改进;o_O???
    如果你觉得该文章有一点点用处,可以给作者点个赞;\\*^o^*//
    如果你想要和作者一起进步,可以微信扫描二维码,关注前端老L;~~~///(^v^)\\\~~~
    谢谢各位读者们啦(^_^)∠※!!!

  • 相关阅读:
    GBASE南大通用签约广东省某城市商业银行
    求直角三角形第三点的坐标
    FPGA学习----Verilog HDL语法(2)
    Andy‘s First Dictionary C++ STL set应用
    【SA8295P 源码分析 (三)】128 - GMSL2 协议分析 之 Forward Error Correction (FEC) 正向通道纠错功能介绍
    详解IDEA git 版本回滚
    穿山甲广告位生效时间,广告位不合法,广告位错误等
    给视频批量添加背景图,轻松简单的操作方法
    未来IT新潮:共探技术革命与行业趋势
    Spark Streaming
  • 原文地址:https://blog.csdn.net/weixin_62277266/article/details/126917183
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号