前言
JavaScript函數(shù)可以有默認(rèn)參數(shù)值。通過默認(rèn)函數(shù)參數(shù),你可以初始化帶有默認(rèn)值的正式參數(shù)。如果不初始化具有某些值的參數(shù),則該參數(shù)的默認(rèn)值為undefined。
請看下列代碼:
function foo(num1){console.log(num1);}foo();在調(diào)用函數(shù)foo時,你沒有傳遞任何參數(shù),因此變量num1的默認(rèn)值設(shè)置為undefined。但是,有時你可能需要設(shè)置默認(rèn)值而非undefined。過去,最好的策略是測試參數(shù)值undefined,然后分配一個值。所以,在上面的例子中,如果你想要將num1的默認(rèn)值設(shè)置為9,那么你可以按照以下代碼所示的方式做:
function foo(num1) {if (num1 === undefined) {num1 = 9;}console.log(num1);}foo();ECMAScript 6引入了函數(shù)的默認(rèn)參數(shù)。使用ECMA 2015的默認(rèn)參數(shù)功能,你將不再需要檢查未定義的參數(shù)值。現(xiàn)在,你可以將9設(shè)置為參數(shù)本身的默認(rèn)值。你可以重寫上述函數(shù)以使用默認(rèn)值,如下所示:
function foo(num1 =9) {console.log(num1);}foo();對于函數(shù)foo,如果num1參數(shù)的值未被傳遞,那么JavaScript將設(shè)置9作為num1的默認(rèn)值。
檢查未定義的參數(shù)
即使你在調(diào)用函數(shù)時明確地傳遞undefined作為參數(shù)值,參數(shù)值也將設(shè)置為默認(rèn)值。
function foo(num1 =9) {console.log(num1);}foo(undefined);在上面的代碼中,你傳遞undefined為num1的值;因此,num1的值將被設(shè)置為默認(rèn)值9。
運(yùn)行時計算默認(rèn)值
JavaScript函數(shù)默認(rèn)值在運(yùn)行時計算。為了更好地理解這一點(diǎn),請看以下代碼:
function foo(value = koo()) {return value;}function koo() {return "Ignite UI";}var a = foo();console.log(a);在函數(shù)foo中,參數(shù)值的默認(rèn)值設(shè)置為函數(shù)koo。在運(yùn)行時調(diào)用函數(shù)foo時,將計算函數(shù)koo。調(diào)用foo函數(shù)后,你會得到如下圖所示的輸出(在這個例子中,我們使用了Ignite UI框架)。
重用默認(rèn)參數(shù)
默認(rèn)參數(shù)可供之后的默認(rèn)參數(shù)使用。請看下列代碼:
function foo(num1 = 9, num2 = num1 + 8){console.log(num2);}foo();在上面的代碼中,使用num1的默認(rèn)值來計算num2的默認(rèn)值。調(diào)用函數(shù)foo時將得到以下輸出:
結(jié)論
JavaScript默認(rèn)參數(shù)在編寫函數(shù)時非常有用。在調(diào)用函數(shù)時,如果缺少參數(shù),則默認(rèn)參數(shù)功能允許你為函數(shù)參數(shù)分配默認(rèn)值,而不是將其定義為undefined。
英文原文:Easy JavaScript Part 3: What Is a Default Parameter in a Function?
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。
新聞熱點(diǎn)
疑難解答