JavaScript不检查参数的个数。即使给的参数和函数要求的个数不一致,也不会检查。但是在大多数情况下,只是省略参数的话,程序基本上是不能正常运行的。
为了避免错误,可以使用if语句给函数参数设置默认值:
function getTriangle(base, height){
if(base===undefined){base=1;}
if(height===undefined){height=1;}
return base*height/2;
}
console.log(getTriangle(5)); //结果2.5
以上只给了一个参数5,因此后面的参数height被忽略,则使用默认值height=1。或者使用以下的语句:
function getTriangle(base=1,height=1){
return base*height/2;
}
console.log(getTriangle(5); //结果=2.5
这一段语句表达的意义和上一条语句一样。
function getTriangle(base,height=base){
return base*height/2;
}
console.log(getTriangle(10,5)); //结果等于25;
console.log(getTriangle(3); //结果等于9;(赋值了base=3,参数height=base=3)
需要注意,将其他参数设置为默认值是,只能设定改参数之前定义了的参数。
(1)可以应用默认值的情况和不能应用默认值的情况:
只有在没有显式传递参数是才可以应用默认值。因此即使显式地传递了如null、false、0或空字符串等表示空的值,也不能应用默认值。比如:
function getTriangle(base=1,height=1){
return base*height/2;
}
console.log(getTriangle(5,null)); //结果为0;
没有应用到第二个参数height的默认值,5Xnull/2=0。
但是如果把null替换为undifined时,视为没有传递参数,并应用默认值。
(2)拥有默认值的形参放在参数列表的末尾
function getTriangle(base=1,height){
return base*height/2;
}
console.log(getTriangle(5));
参数5传递给了base。结果=5Xundifined/2的NaN(not a number)。因此在这样的函数中,可以理解为base是必须的,不能只给height传递值。然而这样的语句是不严谨的。
*如果要表示参数可以省略,可以加入前缀“o_”,如 o_base,来区分必须的参数(仅仅为了易于理解和阅读)。
定义可变参数函数
可变参数函数指「参数的个数不一定的函数」。
function sum(){
var result=0;
for (var i=0, len=arguments.length; i<len; i++){
var tmp=arguments[i];
if(typeof tem !=='number'){
throw new Error('not a number'+tmp);
}
result += tmp;
}
return result;
}
try{
console.log(sum(1,3,5,7,9));
}catch(e){
window.alert(e.message)
}
在形参的前面添加「…」能成为可变参数(英语写为Rest Parameter)。是将收到的任意个数的参数作为数组接收的功能。
function sum(...nums){
let result=0;
for(let num of nums){
if(typeof num!=='number'){
throw new Error('value not exist'+num);
}
result+=num;
}
return result;
}
try {
console.log(sum(1,3,5,7,9));
}catch(e){
window.alert(e.message);
}
(1)函数接收可变参数更容易理解;
(2)具有所有的数组操作。