JavaScript学习笔记(10):参数的各种表示法

JavaScript学习笔记(10):参数的各种表示法,第1张

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

在形参的前面添加「…」能成为可变参数(英语写为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)具有所有的数组 *** 作。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1321250.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-12
下一篇 2022-06-12

发表评论

登录后才能评论

评论列表(0条)