时间:2021-05-25
前言
JavaScript函数可以有默认参数值。通过默认函数参数,你可以初始化带有默认值的正式参数。如果不初始化具有某些值的参数,则该参数的默认值为undefined。
请看下列代码:
function foo(num1){console.log(num1);}foo();在调用函数foo时,你没有传递任何参数,因此变量num1的默认值设置为undefined。但是,有时你可能需要设置默认值而非undefined。过去,最好的策略是测试参数值undefined,然后分配一个值。所以,在上面的例子中,如果你想要将num1的默认值设置为9,那么你可以按照以下代码所示的方式做:
function foo(num1) {if (num1 === undefined) {num1 = 9;}console.log(num1);}foo();ECMAScript 6引入了函数的默认参数。使用ECMA 2015的默认参数功能,你将不再需要检查未定义的参数值。现在,你可以将9设置为参数本身的默认值。你可以重写上述函数以使用默认值,如下所示:
function foo(num1 =9) {console.log(num1);}foo();对于函数foo,如果num1参数的值未被传递,那么JavaScript将设置9作为num1的默认值。
检查未定义的参数
即使你在调用函数时明确地传递undefined作为参数值,参数值也将设置为默认值。
function foo(num1 =9) {console.log(num1);}foo(undefined);在上面的代码中,你传递undefined为num1的值;因此,num1的值将被设置为默认值9。
运行时计算默认值
JavaScript函数默认值在运行时计算。为了更好地理解这一点,请看以下代码:
function foo(value = koo()) {return value;}function koo() {return "Ignite UI";}var a = foo();console.log(a);在函数foo中,参数值的默认值设置为函数koo。在运行时调用函数foo时,将计算函数koo。调用foo函数后,你会得到如下图所示的输出(在这个例子中,我们使用了Ignite UI框架)。
重用默认参数
默认参数可供之后的默认参数使用。请看下列代码:
function foo(num1 = 9, num2 = num1 + 8){console.log(num2);}foo();在上面的代码中,使用num1的默认值来计算num2的默认值。调用函数foo时将得到以下输出:
结论
JavaScript默认参数在编写函数时非常有用。在调用函数时,如果缺少参数,则默认参数功能允许你为函数参数分配默认值,而不是将其定义为undefined。
英文原文:Easy JavaScript Part 3: What Is a Default Parameter in a Function?
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在上篇文章中我们讨论了javascript中的默认参数,这篇文章,我们来讨论下javascript的arguments参数对象。如下例的一个函数,我们如何根据传
本文将讨论使JavaScript函数更有表现力的两个特性:Rest参数和参数默认值。Rest参数通常,我们需要创建一个可变参数的函数,可变参数是指函数可以接受任
一、默认参数在C++中,可以为参数指定默认值。在函数调用时没有指定与形参相对应的实参时,就自动使用默认参数。默认参数的语法与使用:(1)在函数声明或定义时,直接
1.带默认值的参数在了解带星号(*)的参数之前,先看下带有默认值的参数,函数定义如下:>>defdefaultValueArgs(common,defaultS
首先想说说javascript中函数的隐含参数:argumentsArguments该对象代表正在执行的函数和调用它的函数的参数。[function.]argu