位置: 编程技术 - 正文

探讨JavaScript中的Rest参数和参数默认值(javascriptcsdn)

编辑:rootadmin

推荐整理分享探讨JavaScript中的Rest参数和参数默认值(javascriptcsdn),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:简要说明javascript的作用,javascript的理解,简述javascript,javascript的理解,javascript definitive guide,细说javascript,javascript definitive guide,简述javascript,内容如对您有帮助,希望把文章链接给更多的朋友!

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参数和参数默认值(javascriptcsdn)

与 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 这两个编译器都已经支持了参数默认值,所以你可以大胆使用。

结论

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

标签: javascriptcsdn

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

上一篇:JavaScript中的cacheStorage使用详解(JavaScript中的方法名不区分大小写)

下一篇:浅谈JavaScript的Polymer框架中的事件绑定(javascript的prompt)

  • 增值税专用发票电子发票可以抵扣吗
  • 农机企业所得税税率
  • 递延所得税负债转回怎么理解
  • 上年度暂估的票回不来一直挂帐吗
  • 出口退税三类企业指什么意思
  • 汇款退回来的可以不做账吗
  • 应缴纳的增值税计算公式
  • 如何保证企业生存发展
  • 税局函调准备哪些资料
  • 预借差旅费,付给现金会计分录
  • 生产车间用电产品有哪些
  • 商业企业购进应税消费品可以抵扣吗
  • 银行汇兑怎么做账
  • 研发费用的台账有哪些
  • 开票金额大于收款金额如何处理
  • 应交所得税的计算例题
  • 发票密码区超出还能用吗
  • 技术服务发票是劳务发票吗
  • 企业增值税不可以跨月交吗
  • 工资一定要通过应付工资科目吗
  • 企业有哪些资金结构
  • 怎么处理有问题的货物
  • 当月有进项税额转出怎么结转未交增值税
  • 在王者荣耀中怎么找个妹子
  • 忘记excel工作表保护密码怎么办
  • windows11怎么添加打印机驱动
  • 收到投资方投入原材料
  • 什么是会计分录其一般表达形式是怎样的
  • 应付账款收到票怎么做账
  • 处置抵债资产的增值税计入
  • 记账凭证和会计分录的区别
  • 外币存款业务
  • vue项目开发环境
  • lxml&xpath一站式教学
  • 论文阅读网站排行榜
  • Laravel+jQuery实现AJAX分页效果
  • 营业税金及附加会计分录
  • 电子商业汇票线下清算流程
  • 企业增值税发票税率是多少
  • 公司新增注册资本是认缴的吗
  • mysql5.7.27安装与配置
  • 自然人独资公司可以变更法人吗
  • 个税申报子女教育有年龄限制吗
  • 应付账款发生坏账怎么办
  • 经营性收入包括成本吗
  • 事业单位银行开户规定
  • 其他收益里的政府是什么
  • 待抵扣进项税额是二级还是三级
  • 金融企业里面的债务
  • 国有控股企业和国有参股企业的区别
  • 开票方没有缴纳增值税
  • 房地产企业怎么交房产税
  • 业务招待费能计入项目成本吗
  • 实收资本印花税税率多少
  • 残保金超比例奖励政策
  • 从个人处借款的会计分录
  • 公司增资怎么处理
  • 待认证进项发票哪里导出来数据
  • 跨期发票会计处理
  • 投资收益主要包括哪些
  • 工业企业存货发出计价的方法
  • win8 win8.1
  • mac osx 10.12
  • win7怎么启用显卡
  • 用户访问控制手段
  • javascriptz
  • android secure
  • python 500行
  • time(0)函数
  • Node.js中的事件循环是什么样的
  • 从零开始学什么好
  • 手机关卡类游戏
  • 电子发票查询系统手机查询
  • 汽车运输发票税率是多少
  • 合伙企业如何申报税务报表
  • 承租房变更承租人申请怎么写
  • 发票明细怎么导入开票系统里
  • 国家个人所得税征收标准
  • 2021年税务高雅春联带横批
  • 盘州市税务局党组成员图片
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设