[ES6系列-03]ES6中关于参数相关特性详解(参数默认值与参数解构赋值与剩余参数)
[原创] 码路工人
大家好,这里是码路工人有力量,我是码路工人,你们是力量。
今天总结一下 ES6 中跟参数相关的内容。
欢迎补充斧正、留言交流。
让我们互相学习一起进步。
1. ES6 参数默认值(非必需参数/可选参数)
在 ES6 之前,函数的参数是无法设默认值的,聪明的人们当然有变通的方式,通过判断来参在函数刚开始给它赋上预想的初始值。具体在这篇里有介绍。
扩展阅读: [ES5 中参数默认值的手动实现][ES5Parameter]
到了 ES6,就可以愉快地设定参数默认值了。在下面的
defaultParamInEnd函数中,用age = 18来设了默认值。/* eg.0
* set default value for parameters
*/
//------------------------------------------------- const defaultParamInEnd = function(name, age = 18) {
console.log(`name: ${name} -- age: ${age}`)
} defaultParamInEnd("Coder Power")
// name: Coder Power -- age: 18 defaultParamInEnd("Coder Power", 32)
// name: Coder Power -- age: 32 //-------------------------------------------------
上面的例子中,设默认值放在了末尾,也是我们 CSharper 惯用的方式,当多个参数有默认值时也是连续地放在尾部。
C#中不允许设默认值的参数出现在中间或者不连续,所有可选参数必须放在必需参数的后面。那
js中可不可以,带默认值的参数(也就是非必须参数),不在最后的位置呢?下面例子中我们来试一下。
```javascript
/* eg.1
* default value of parameters
*/
//-------------------------------------------------
const defaultParamInCenter = function(name, age = 18, gender) {
console.log(` name: ${name} -- age: ${age} -- gender: ${gender}`)
}
defaultParamInCenter("Coder Power", undefined, "male")
// name: Coder Power -- age: 18 -- gender: male
defaultParamInCenter("Coder Power", null, "male")
// name: Coder Power -- age: null -- gender: male
//-------------------------------------------------
```
结果显示,非必需参数可以出现在中间位置(后面再跟有必需参数)。
注意在传值上还有以下区别:
- 当我们给带默认值的形参`age`传一个`undefined`的时候,函数里得到了默认值`18`;
- 而当我们传`null`的时候,函数里就没有得到默认值,而是`null`了。
建议在定义函数时还是将非必需参数写在最后,设默认值本身就是为了调用时方便,这样就不必为了凑数去传一个`undefined`,直接不传才是非必须参数设计的初衷。
2. 剩余操作符语法获取剩余参数(Rest operator syntax)
...(
...既是剩余操作符语法又是展开操作符语法Spread operator syntax,这个另做介绍)/* eg.2
* rest parameters
*/
//------------------------------------------------- function restParams(name, ...other) {
console.log(`name: ${name}`)
console.log(`other: ${other}`)
} restParams("Coder Power", 18, "male")
// name: Coder Power
// other: 18,male //-------------------------------------------------
从上面的打印信息中
other: 18,male能够看出,other里放了两个值,也就是剩下的两个参数的值都被它自己接收了。而如果没有剩余参数操作符语法,它肯定还是只能接收一个值(也就是第二个参数的值)。这里码路工人认为可以这么理解:
...首先会把它后面传来的参数收集起来,相当于放进[ ]数组,再充当展开操作符语法,相当于做了个拷贝塞到形参other里。
或者直接理解为把传过来的剩余参数用展开操作符语法塞到形参other里。- 脑洞一下:展开操作符语法可以不用在参数末尾吗?
/* eg.3
* rest parameter operator not in end
*/
//------------------------------------------------- function restParamsNotInEnd(...someParams, gender) {
console.log(`other: ${other}`)
console.log(`someParams: ${someParams}`)
} restParamsNotInEnd("Coder Power", 18, "male")
// SyntaxError: Rest parameter must be last formal parameter //-------------------------------------------------
结果报错了,异常信息显示
剩余参数必须置于最后位置。
- 脑洞一下:展开操作符语法可以不用在参数末尾吗?
3. 参数的解构赋值(Destructuring Assignment)
如果一个方法处理内容简单仅仅用到了一个对象的个别属性,而接收的参数是一个完整的对象时,可以只解构获取想要的内容(也可以是全部属性)。
/* eg.4
* Destructuring Assignment of parameters
*/
//------------------------------------------------- const person = {
name: "Coder Power",
age: 18,
gender: "male",
mail: "test@abc.com",
sister: [
{
name: 'Emily',
age: 22,
gender: "female"
},
{
name: 'Lucy',
age: 15,
gender: "female"
}
],
address: "avenue city province country"
} function sayHello ({ name, age, birthday = 20101219 }) {
console.log(`Hello! I'am ${ name }, ${ age } years old.`)
} sayHello(person)
// Hello! I'am Coder Power, 18 years old. //-------------------------------------------------
实际上
{ }解构不仅仅可以用在参数上,写在函数内也是一样的效果。
这同样还体现在后面要讲到的模块化导入 import的使用上。
注意:参数里的解构赋值不支持取别名,其它解构支持别名
但是可以赋默认值
/* eg.4
* default value for Destructuring Assignment of parameters
*/
//------------------------------------------------- function sayHelloAgain ({ name, age, birthday = 19860101 }) {
console.log(`Hello! I'am ${ name }, ${ age } years old.`)
console.log(`Birthday: ${ birthday}`)
} sayHelloAgain(person)
// Hello! I'am Coder Power, 18 years old.
// Birthday: 19860101 //-------------------------------------------------
上面的示例中打印出了
birthday的默认值。
关于 ES6 中参数相关的内容就介绍到这里,其中用到的还没有讲到的特性,会在后续的文章中一一介绍。
欢迎谬误斧正和转发分享。还可以评论区留个言再走啊~
希望对你能有帮助,下篇再见。
[ES6系列-03]ES6中关于参数相关特性详解(参数默认值与参数解构赋值与剩余参数)的更多相关文章
- ES6系列之项目中常用的新特性
ES6系列之项目中常用的新特性 ES6常用特性 平时项目开发中灵活运用ES6+语法可以让开发者减少很多开发时间,提高工作效率.ES6版本提供了很多新的特性,接下来我列举项目中常用的ES6+的特性: l ...
- LINQ系列:C#中与LINQ相关特性
1. 匿名类型 通过关键字var定义匿名类型,编译器将根据运算符右侧表达式的值来发出一个强类型. 使用匿名类型时要遵守的一些基本规则: ◊ 匿名类型必须有一个初始化值,而且这个值不能是空值(null) ...
- 单元测试系列之十一:Jmockit之mock特性详解
本文是Jmockit学习过程中,根据官网所列的工具特性进行解读. 1.调用次数约束(Invocation count constraints) 可以通过调用计数约束来指定预期和/或允许匹配给定期望的调 ...
- 研究下JavaScript中的Rest參数和參数默认值
研究下JavaScript中的Rest參数和參数默认值 本文将讨论使 JavaScript 函数更有表现力的两个特性:Rest 參数和參数默认值. Rest 參数 通常,我们须要创建一个可变參数的函数 ...
- PHP 判断是表单否有这个参数,如果没有则设置默认值
<?php @$name = $_GET["name"]; if(isset($name)) { echo "name = " .$name; } els ...
- 获取列表数据时,getList 设置默认参数:getList(page = 1),点击分页及前往时,传page参数,其他使用page的默认值:1
获取列表数据时,getList 设置默认参数:getList(page = 1),点击分页及前往时,传page参数,其他使用page的默认值:1
- PyQt(Python+Qt)入门:Designer组件属性编辑界面中QWidget类相关属性详解
本文适用人员:本文比较长,适合不理解Qt Designer部件属性的人员阅读或资料查找. 声明: 1.如果有人认为本文是简单的复制粘贴+翻译而成,敬请读本文最后的后记: 2.本文为老猿Python学习 ...
- Flink-1.10中的StreamingFileSink相关特性
一切新知识的学习,都离不开官网得相关阅读,那么StreamingFileSink的官网介绍呢? https://ci.apache.org/projects/flink/flink-docs-rele ...
- flutter系列之:flutter中常用的GridView layout详解
目录 简介 GridView详解 GridView的构造函数 GridView的使用 总结 简介 GridView是一个网格化的布局,如果在填充的过程中子组件超出了展示的范围的时候,那么GridVie ...
随机推荐
- The Preliminary Contest for ICPC Asia Xuzhou 2019 徐州网络赛 K题 center
You are given a point set with nn points on the 2D-plane, your task is to find the smallest number o ...
- Dubbo(六):zookeeper注册中心的应用
Dubbo中有一个非常本质和重要的功能,那就是服务的自动注册与发现,而这个功能是通过注册中心来实现的.而dubbo中考虑了外部许多的注册组件的实现,zk,redis,etcd,consul,eurek ...
- 从0开始学自定义View -1
PS:好久没有写博客了,之前的东西有所忘记,百度一下竟然查到了自己的写过的博客,访问量还可以,一开始的写博客的初衷是把自己不会的记录下来,现在没想到也有博友会关注我,这就给了我动力,工作之余把零零碎碎 ...
- C语言程序设计实验报告(第一次实验)
C程序设计实验报告 实验项目:C语言程序设计教程实验1.3.2:1.3.3:1.3.4:2.3.1:2.3.2 姓名:赖瑾 实验地点:家 实验时间:2020.2.25 目录 C程序设计实验报告 一.实 ...
- CC2530外部中断
一.中断基础概念 内核与外设之间的主要交互方式有两种:轮询和中断.中断系统使得内核具备了应对突发事件的能力. 在执行CPU当前程序时,由于系统中出现了某种急需处理的情况,CPU暂停正在执行的程序,转 ...
- 认识mysql3个基本库
一.3个基本库 数据库初始化安装完毕会有三个基本库mysql .information_schema.performace_schema.作为应用程序开发者,平时较少关注这些数据库尤其是后两者.但是通 ...
- 操作系统实验——PV操作实现生产者消费者模型
操作系统PV操作之--生产者消费者模型 个人博客主页 参考资料: Java实现PV操作 | 生产者与消费者 浙大公开课 在操作系统的多进程.多线程操作中经常会有因为同步.互斥等等问题引发出的一系列问题 ...
- [CodeForces 344C Rational Resistance]YY,证明
题意:给若干个阻值为1的电阻,要得到阻值为a/b的电阻最少需要多少个. 思路:令a=mb+n,则a/b=m+n/b=m+1/(b/n),令f(a,b)表示得到a/b的电阻的答案,由f(a,b)=f(b ...
- aop面向切面编程的实现
aop主要用于日志记录,跟踪,优化和监控 下面是来自慕课网学习的一些案例,复制黏贴就完事了,注意类和方法的位置 pom添加依赖: <dependency> <groupId>o ...
- Angular 初体验
事情起源当初一个简单的截屏然后推流出去的工具,这个工具当初我用winform简单实现了下,然后因公司业余,添加许多程序包,需要自动管理这些程序包,包含下载更新上传等,以及与后台交互,学生老师提醒,自动 ...