Javascript中的默認(rèn)參數(shù)詳解
一些語(yǔ)言——像Ruby,CoffeeScript及即將到來(lái)的javascript版本——在定義一個(gè)函數(shù)的時(shí)候,可以聲明默認(rèn)參數(shù),像下面這樣:
function myFunc(param1, param2 = "second string") {
console.log(param1, param2);
}
// Outputs: "first string" and "second string"
myFunc("first string");
// Outputs: "first string" and "second string version 2"
myFunc("first string", "second string version 2");
不幸的是,在當(dāng)前的javascript版本,這種寫(xiě)法的無(wú)效的。因此,我們能做些什么來(lái)實(shí)現(xiàn)這種方式,使用我們現(xiàn)有的工具集?
最簡(jiǎn)單的解決方式像這樣:
function myFunc(param1, param2) {
if (param2 === undefined) {
param2 = "second string";
}
console.log(param1, param2);
}
// Outputs: "first string" and "second string version 2"
myFunc("first string", "second string version 2");
事實(shí)是一個(gè)被省略的參數(shù)在訪問(wèn)時(shí)總是“undefined”。如果你只有一個(gè)參數(shù),這是一個(gè)好的解決方式,當(dāng)時(shí)如果有多個(gè)呢?
如果你多于一個(gè)參數(shù),你可以使用一個(gè)對(duì)象作為參數(shù),這樣有一個(gè)優(yōu)點(diǎn)是每個(gè)參數(shù)都有一個(gè)明確的命名。如果你傳遞一個(gè)對(duì)象參數(shù),你可以使用相同的方式聲明默認(rèn)值。
function myFunc(paramObject) {
var defaultParams = {
param1: "first string",
param2: "second string",
param3: "third string"
};
var finalParams = defaultParams;
// We iterate over each property of the paramObject
for (var key in paramObject) {
// If the current property wasn't inherited, proceed
if (paramObject.hasOwnProperty(key)) {
// If the current property is defined,
// add it to finalParams
if (paramObject[key] !== undefined) {
finalParams[key] = paramObject[key];
}
}
}
console.log(finalParams.param1,
finalParams.param2,
finalParams.param3);
}
myFunc({param1: "My own string"});
這是一個(gè)有點(diǎn)笨拙,如果你使用這種方式的地方很多,可以寫(xiě)個(gè)封裝函數(shù),幸運(yùn)的是,現(xiàn)在好多庫(kù)中帶了相關(guān)方法,比如jQuery和Underscore中的extend方法。
下面使用Underscore的extend方法來(lái)實(shí)現(xiàn)上面相同的結(jié)果:
function myFunc(paramObject) {
var defaultParams = {
param1: "first string",
param2: "second string",
param3: "third string"
};
var finalParams = _.extend(defaultParams, paramObject);
console.log(finalParams.param1,
finalParams.param2,
finalParams.param3);
}
// Outputs:
// "My own string" and "second string" and "third string"
myFunc({param1: "My own string"});
這就是你如何能得到默認(rèn)參數(shù),在當(dāng)前的javascript版本中。
文中不妥之處歡迎批評(píng)指正。
相關(guān)文章
javascript prototype原型詳解(比較基礎(chǔ))
prototype原型是javascript中特別重要的概念,屬于必須要掌握,如果沒(méi)有良好的掌握的話,進(jìn)一步用好或者學(xué)好js基本是不可能的實(shí)現(xiàn)的事情,并且此概念稍有難度,可能對(duì)于初次接觸的朋友來(lái)說(shuō)有點(diǎn)困難,下面就通過(guò)代碼實(shí)例簡(jiǎn)單介紹一下prototype原型的用法2016-12-12
JavaScript程序中實(shí)現(xiàn)繼承特性的方式總結(jié)
JavaScript是一門(mén)強(qiáng)行聲稱面向?qū)ο蟮恼Z(yǔ)言,而繼承是面向?qū)ο蟮囊淮笾饕匦?這里我們根據(jù)阮一峰老師的文章來(lái)看一下JavaScript程序中實(shí)現(xiàn)繼承特性的方式總結(jié)2016-06-06
javascript indexOf函數(shù)使用說(shuō)明
JavaScript中indexOf函數(shù)方法是返回 String 對(duì)象內(nèi)第一次出現(xiàn)子字符串的字符位置。2008-07-07
JavaScript Math.ceil 方法(對(duì)數(shù)值向上取整)
js Math.ceil用于對(duì)數(shù)值向上取整,即得到大于或等于該數(shù)值的最小整數(shù),需要的朋友可以參考下2015-01-01

