位置: 编程技术 - 正文

深入学习JavaScript中的Rest参数和参数默认值(深入学习习总书记系列讲话精神)

编辑:rootadmin

推荐整理分享深入学习JavaScript中的Rest参数和参数默认值(深入学习习总书记系列讲话精神),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:深入学习习总书记系列讲话精神,java deep learning,java深入理解,深入理解java nio,深入学习习总书记系列讲话精神,深入学习习总书记系列讲话精神,深入学习习总书记系列讲话精神,深入学习习总书记系列讲话精神,内容如对您有帮助,希望把文章链接给更多的朋友!

本文将讨论使 JavaScript 函数更有表现力的两个特性:Rest 参数和参数默认值。Rest 参数

通常,我们需要创建一个可变参数的函数,可变参数是指函数可以接受任意数量的参数。例如,String.prototype.concat 可以接受任何数量的字符串作为参数。使用 Rest 参数,ES6 为我们提供一种新的方式来创建可变参数的函数。

我们来实现一个示例函数 containsAll,用于检查一个字符串中是否包含某些子字符串。例如,containsAll("banana", "b", "nan") 将返回true,containsAll("banana", "c", "nan") 将返回 false。

下面是传统的实现方式:

该实现用到了 arguments 对象,该对象是一个类数组对象,包含函数被调用时的实参列表。这段代码正是我们想要的,但其可读性却不是最优的。函数只有一个形参 haystack,所以不可能一看就知道该函数需要多个参数,并且在遍历 arguments 时,需要特别注意遍历的开始索引为1 ,而不是常见的 0,因为 arguments[0] 就是函数定义时的形参 haystack。如果我们想在 haystack 参数之前或之后添加一些参数,我们不得不更新内部的循环。Rest 参数解决了这些问题,下面是 使用 Rest 参数的实现方式:

以上两个实现都满足了我们的需求,但后者包含一个特殊的 ...needles 语法。我们来看看调用containsAll("banana", "b", "nan") 时的细节,参数 haystack 和以往一样,将用函数的第一个实参填充,值为 "banana",needles 前面的省略号表示它是一个 Rest 参数,剩余的所有实参将被放入一个数组中,并将该数组赋给 needles 遍量。在这个调用中,needles 的值为 ["b", "nan"]。然后,就是正常的函数执行了。

只能将函数的最后一个函数作为 Rest 参数,在函数被调用时,Rest 参数之前的参数都将被正常填充,之外的参数将被放入一个数组中,并将该数组作为 Rest 参数的值,如果没有更多的参数,那么 Rest 参数的值为一个空数组 [],Rest 参数的值永远都不会是 undefined。参数的默认值

通常,调用一个函数时,不需要调用者传递所有可能的参数,那些没有传递的参数都需要一个合理的默认值。JavaScript 对那些没有传递的参数都有一个固定的默认值 undefined。在 ES6 中,引入了一种新方法来指定任意参数的默认值。

看下面例子:

在每个参数的 = 后面是一个表达式,指定了参数未传递时的默认值。所以,animalSentence() 返回 "Lions and tigers and bears! Oh my!", animalSentence("elephants") 返回"Lions and elephants and bears! Oh my!", animalSentence("elephants", "whales") 返回 "Lions and elephants and whales! Oh my!"。

深入学习JavaScript中的Rest参数和参数默认值(深入学习习总书记系列讲话精神)

参数默认值需要注意的几个细节:

与 Python 不一样的是,参数默认值的表达式是在函数调用时从左到右计算的,这意味着表达式可以使用前面已经被填充的参数。例如,我们可以将上面的函数变得更有趣一点:

那么,animalSentenceFancy("bears") 将返回 "Lions and bears and sealions. Oh my!"。

传递 undefined 等同于没有传递该参数。因此,animalSentence(undefined, "unicorns") 将返回 "Lions and tigers and unicorns! Oh my!"。 如果没有为一个参数指定默认值,那么该参数的默认值为 undefined,所以

等同于

抛弃 arguments

通过 Rest 参数和参数的默认值,我们可以完全抛弃 arguments 对象,使我们的代码可读性更高。此外,arguments 对象也加深了优化 JavaScript 的难题。

希望以上两个新特性可以完全取代 arguments。作为第一步,在使用 Rest 参数或参数的默认值时,请避免使用 arguments 对象,假如 arguments 对象还不会立即被移除,或者永远不会,那么也最好是避免在使用 Rest 参数或参数默认值时使用 arguments 对象。兼容性

Firefox 以上的版本已经支持这两个新特性。然而,除此之外,还没有其他任何浏览器支持。最近,V8 的实验环境添加了对 Rest 参数的支持,而参数默认值还有一个 issue,JSC 也对 Rest 参数和参数默认值提了一些 issue。

Babel 和 Traceur 这两个编译器都已经支持了参数默认值,所以你可以大胆使用。结论

尽管从技术层面上看,这两个新特性在并没有给函数引入新的行为,但它们可以使一些函数的声明更具表现力和可读性。

详解JavaScript ES6中的模板字符串 在ES6中引入了一种新的字符串字面量—模板字符串,除了使用反引号(`)表示,它们看上去和普通的字符串没有什么区别。在最简单的情况下,他们就是

详解JavaScript ES6中的Generator 今天讨论的新特性让我非常兴奋,因为这个特性是ES6中最神奇的特性。这里的神奇意味着什么呢?对于初学者来说,该特性与以往的JS完全不同,甚至有

深入了解JavaScript中的Symbol的使用方法 Symbol是什么?Symbols不是图标,也不是指在代码中可以使用小图片:也不是指代其他一些东西的语法。那么,Symbol到究竟是什么呢?七种数据类型JavaScript

标签: 深入学习习总书记系列讲话精神

本文链接地址:https://www.jiuchutong.com/biancheng/377568.html 转载请保留说明!

上一篇:详细解读JavaScript编程中的Promise使用(详细解读了)

下一篇:详解JavaScript ES6中的模板字符串

  • 买车要交哪些税收
  • 职工意外伤害险赔偿范围
  • 员工加班误餐费怎么做凭证
  • 小企业会计准则以前年度损益调整
  • 公司个人薪金怎么申报宁波
  • 税务机关和自然人属于平等主体吗
  • 原材料被盗计入什么科目
  • 分类账和明细账平行登记规则
  • 应付职工薪酬如何填列
  • 房地产契税新政策2021退税
  • 总账期末余额为零怎么写
  • 补充医疗保险 个人账户可以报销吗
  • 高速公路通行费怎么计算的
  • 贸易公司购买汽车的发票可以用抵公司的税吗
  • 2018手写发票何时失效?
  • 进项抵扣抵扣
  • 工程会计做账流程及会计分录
  • 房地产行业应收帐款周转率平均值
  • 公司办公楼转让缴纳增值税的依据
  • 建筑公司开劳务票税点是多少
  • 盈亏平衡点定价法例题及答案
  • 坏账准备本期期末应有金额
  • 行政单位对固定资产购买保险
  • 应计提的存货跌价准备
  • 社保已申报但未缴费有什么影响
  • 小规模库存商品结转成本太低怎么办
  • 生物资产全套账务处理
  • win11怎么回到10
  • 会计上金融资产包括哪些
  • 应收票据的核算账户有哪些
  • 公司费用高好还是低好
  • Http请求-hutool工具类的使用
  • php教程全集
  • 黄金期货交易要怎么样
  • 企业合并发生的审计费用,评估费用会计分录
  • auto系列软件
  • php验证码扭曲效果怎么做
  • 查补的增值税账务处理
  • uniapp跨域解决方案
  • dir命令linux
  • 利息发票可以抵扣吗
  • 销售精装修房如何做账
  • linux mongodb创建用户
  • 个体工商户可以抵扣进项吗
  • mysql存储引擎的作用
  • sql死锁的简单例子
  • 企业支付的佣金计算多少税率呢
  • 补贴收入属于其他收益吗
  • 薪酬范围怎么写
  • 亏损企业对外捐赠的税前扣除
  • 开票方未缴税,为何要追回付款方的退税款
  • 原材料暂估入库是什么意思
  • 工程款抵房款什么意思
  • 合同资产结转收入
  • 增值税年末必须要交吗
  • 收到房租费发票如何做账
  • 支票丢失需要登报吗
  • 个体工商户如何给员工交五险一金
  • 货币资金核算制度是什么
  • mysql索引数据结构有哪些
  • ubuntu右键菜单
  • 电脑windows不可用怎么办
  • win8开机logo
  • Win10如何禁止显卡驱动自动更新
  • macbookair安装rosetta
  • 在windows 7中任务栏儿
  • win8 开始
  • win8桌面右键无法使用
  • win8 网络连接
  • win8怎么用一键ghost
  • win10系统如何在管理页面设置共享
  • jquery常用动画制作
  • Android的AsyncTask官方API谷歌翻译版
  • 零磁道的重要性
  • Jquery uploadify上传插件使用详解
  • jquery给td设置内容
  • jquery点击事件写法
  • Javascript中Array.prototype.map()详解
  • 西安房屋契税退税政策2020年
  • 河南省地税网上营业厅
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设