学JS的心路历程-函式(六)其余参数及预设参数
今天我们要来介绍ES6新增的其余参数及预设参数!
其余参数rest parameter
…numbers可以让我们表示不确定数量的参数,并将其视为一个数组:
function getVal(…numbers){
console.log(numbers);
}
getVal(1,24,5,6,7);//[[1,24,5,6,7]]
function getVal(first,…numbers){
console.log(first,numbers);
}
getVal(1,24,5,6,7);//1 [24,5,6,7]
这边要注意到的是,只能在函式最后一个参数作使用,否则会报错误:
function getVal(…numbers,last){
console.log(numbers);
}
//SyntaxError: Rest parameter must be last formal parameter
可能会有人认为我用之前的arguments就好了,为什么要多学一个其余参数的用法?这边我们来列出两者的差异:
arguments是类数组,无法使用一般数组的方法像map、sort,
其余参数为数组则可以使用
arguments物件自身有额外的功能,例如callee属性(radiographersreporting)。
所以我们今天要写一个由大到小排列的函式,用其余参数就会轻松许多:
function mutilMax(…numbers){
var sorted = numbers.sort((a,b)=>b-a);
return sorted;
}
mutilMax(1,24,5,6,7);// [24,7,6,5,1]
如果用arguments需要先把它转成数组才能使用:
function mutilMax(){
var arr = Array.from(arguments);
var sorted = arr.sort((a,b)=>b-a);
return sorted;
}
mutilMax(1,24,5,6,7);
预设参数default parameter
有时候我们会希望函式传进来的参数是固定值,像是:
function personCheck(name,check){
return name+“”+check;
}
personCheck(“Ann”,“checked”);//“Ann checked”
personCheck(“Lia”,“checked”);//“Lia checked”
personCheck(“Una”,“checked”);//“Una checked”
这时候我们会作修改:
function personCheck(name,check){
check = typeof(check)===“undefined”?“checked“:check;
return name+“”+checked;
}
personCheck(“Ann”);//“Ann checked”
personCheck(“Una”);//“Una checked”
personCheck(“Jason”,“not here”);//“Jason not here”
这边看到的typeof(checked)===“undefined”?“checked“:checked代表如果今天没有传入参数checked会是undefined则预设为”checked“,否则回传传入参数。
但是这样还是很麻烦,能不能在精简写法呢?
幸好ES6提供了预设参数功能:
function personCheck(name,check =“checked”){
return name+“”+check;
}
personCheck(“Ann”);//“Ann checked”
personCheck(“Una”);//“Una checked”
personCheck(“Jason”,“not here”);//“Jason not here”
如果指定了一个值,预设值就会被覆盖。是不是方便很多了呢!
预设参数除了可以指派数字和字串,也能指派物件、数组设置函式:
function personCheck(name,check =“checked”,message = name+“”+check){
return message;
}
personCheck(“Una”);//“Una checked”
personCheck(“Jason”,“not here”);//“Jason not here”
但老实说,这程序的可读性实在不怎么好,所以要斟酌使用喔!
来源:(http://www.pamaj-appareL.com)
学JS的心路历程-函式(六)其余参数及预设参数的更多相关文章
- 学JS的心路历程 -函式(三)this
this是什么,取决于被呼叫的呼叫地点. 昨天有提到说,呼叫函式时候会传递隐含参数:arguments和this并讲解了arguments,今天我们就来探讨this吧! 什么是this 我们都会呼叫函 ...
- 学JS的心路历程-函式(二)arguments
参数(argument)与函式参数(parameter) 在讨论函式时,很多人都会把这两个搞混,我自己也不例外. 虽然讲错别人也听得懂,但是我们还是要搞清楚这两个的定义到底是什么! 参数是当我们呼叫函 ...
- 学JS的心路历程-函式(五)箭头函式
箭头函式arrow function 为了能够以更简短的方式建立函式,ES6变推出了箭头函式. 用说明的可能会不太懂,我们先拿之前的数组排序例子来看: var arr = [2,1,6,12,3,77 ...
- 学JS的心路历程-函式(四)apply、call
从上一篇可以知道,不同的函式呼叫会造成this的不同,但我们能不能在呼叫时候明确指定呢? 当然可以.会有这个想法是因为往往在执行某支函式时想要用回呼函式(mizumisushi),但发现this总是显 ...
- 学习JS的心路历程-函式(一)
前几天有间单提到该如何声明函式及在Hositing中会发生什么事,但是函式的奥妙不仅于此. 身为一个使用JS的工程师,我们一定要熟悉函式到比恋人还熟! 这几天将会把函式逐一扒开跟各位一起探讨其中的奥妙 ...
- 学JS的心路历程-JS支持面向对象?(一)
昨天在看Prototype看到JS支持面向对象,被前辈问到说那什么是面向对象?JS是面向对象语言吗? 便开始了一连串艰辛爬文过程,今天就来看一下两者有什么差异吧(rgwyjc)! 首先面向对象有三大特 ...
- 学JS的心路历程 - JS的Class
没错,你没有看错,虽然前面说JS是原型继承,但在ES6以后新增了class关键字!!! 不过底层实作仍然是以原型继承方式进行,所以基本上算是一个语法糖. 今天我们就来看一下如何使用吧! class 首 ...
- 学JS的心路历程-物件与原型(三)
昨天有说明到函式与建构式的原型,及指定建构式函式原型为另一个建构式函式,但其实这会造成复写constructor的问题. 复写constructor的问题(vmwork) 我们昨天有提到「建构式函式可 ...
- 学JS的心路历程 -物件与原型(二)
昨天有提到说Object.setPrototypeOf可以指定一个物件为另一个物件的原型,但有想过到底这个原型,也就是[[Prototype]]最终会到何处吗? 答案是Object.prototype ...
随机推荐
- .NET发送邮箱(验证码)
先看下前端: 写代码前先设置: 一:登录QQ邮箱,点击设置 二: 三: //下面开始敲代码... //两个命名空间 //using System.Net; //using System.Net.Mai ...
- django中路由系统和视图的对应关系(值的传递)-->主要内容(位置参数、关键字参数、额外参数、include分组[urls的分发]、命名分组、反向解析、APPEND_SLASH)
路由系统也就是 urls.py文件,视图就是 views.py文件 路由系统里面要注意的事项 urlpatterns中的元素按照书写顺序从上往下逐一匹配正则表达式,一旦匹配成功则不再继续. 若要从UR ...
- C#分解质因数
using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace app ...
- python变量存储和深浅拷贝
python的变量及其存储 在高级语言中,变量是对内存及其地址的抽象.对于python而言,python的一切变量都是对象,变量的存储,采用了引用语义的方式,存储的只是一个变量的值所在的内存地址,而不 ...
- 干净win7要做几步才能运行第一个Spring MVC 写的动态web程序
干净win7要做几步才能运行第一个Spring MVC 写的动态web程序: 1. 下载安装jdk 2. 配置Java环境变量 3. 测试一下第1,2两步是否完全成功:http://jingyan.b ...
- 【转载】Putty出现 Network error:Software caused connection abort
一.putty發生 network error 开始菜单进入regedit,尋找 HKEY_CURRENT_USER\Software\SimonTatham 并把这个目录下的子目录全部删除,删除前务 ...
- 18.os模块获取url后缀
针对文件下载文件重命名文件后缀的获取,此方式只适用url里有后缀的情况(其它的要根据情况去用类似方式获取字段后缀). import os A="http://www.铜陵市建筑工程信息网.c ...
- 17.1拓展之纯 CSS 创作炫酷的同心圆旋转动画
效果地址:https://codepen.io/flyingliao/pen/ebjEMm?editors=1100 HTML代码: <div class="loader"& ...
- mybatis关系映射之一对多和多对一
本实例使用用户(User)和博客(Post)的例子做说明: 一个用户可以有多个博客, 一个博客只对应一个用户 一. 例子(本实体采用maven构建): 1. 代码结构图: 2. 数据库: t_user ...
- log-bin
装mysql,运行一段时间后,在mysql目录下出现一堆类似mysql-bin.000***,从mysql-bin.000001开始一直排列下来,而且占用了大量硬盘空间,高达几十个G. 对于这些超大空 ...