Javascript是一門非常靈活的編程語言,它有很多方便的特性,其中之一就是允許函數參數設置缺省值。即在定義一個函數的時候,可以為參數賦上一個默認值。在函數調用時,如果沒有提供該參數,那么將使用默認值。本文將重點介紹Javascript參數缺省值的使用方法和注意事項。
舉個例子,我們定義一個函數,用來計算兩個數之和。如果沒有傳遞第二個參數,那么第二個參數默認為0。代碼如下:
```
function add(a, b = 0) {
return a + b;
}
```
在調用該函數時,如果只傳一個參數,那么默認第二個參數為0,返回的結果為參數1的值加上0。例如:
```
console.log(add(2)); // 2
```
如果另外傳入第二個參數的值,那么將用傳入的值代替默認值,返回參數1和參數2之和。例如:
```
console.log(add(2, 3)); // 5
```
經過上面的例子,我們可以看到,設置參數缺省值非常方便實用,特別是在某些參數缺失或者傳值為null時,這個特性就非常有用。下面我們將介紹更多的用例。
1.設置多個缺省值
一個函數定義可以有多個參數,如果需要指定缺省值,可以為每個參數都設置默認值。例如:
```
function createPerson(firstname, lastname, age = 18, gender = 'male') {
return {
firstname,
lastname,
age,
gender,
};
}
```
這個例子中,函數定義了四個參數,其中age和gender可以不傳,默認為18和'male'。如果只傳入前面兩個參數,則age和gender的值都是默認值。
```
console.log(createPerson('Tom', 'Jerry'));
```
輸出結果:
```
{
firstname: 'Tom',
lastname: 'Jerry',
age: 18,
gender: 'male'
}
```
如果傳入全部四個參數,將覆蓋默認值,例如:
```
console.log(createPerson('Mary', 'Bobo', 24, 'female'));
```
輸出結果:
```
{
firstname: 'Mary',
lastname: 'Bobo',
age: 24,
gender: 'female'
}
```
2.不按順序設置缺省值
在函數定義時,可以不按參數順序為某些參數設置缺省值,這樣在調用函數時就可以只傳遞需要傳遞的參數。例如:
```
function add(a, b = 0, c) {
return a + b + c;
}
```
在調用時,如果只需要傳遞第一個和第三個參數,則只需要傳遞這兩個參數即可,第二個參數將使用默認值:
```
console.log(add(1, undefined, 3)); // 4
```
需要注意的是,如果想跳過第二個參數而傳遞第三個參數的值,必須使用undefined作為占位符,不能省略第二個參數。這是因為在Javascript中,省略的參數相當于傳遞了一個undefined的值。
3.缺省值可以是一個動態計算的函數
在定義函數時,我們可以使用一個函數來計算缺省值,而不總是寫死一個靜態值。例如:
```
function getMessage(type, content = getDefaultMessage()) {
return {
type,
content,
}
}
function getDefaultMessage() {
return 'This is a default message';
}
```
在這個例子中,getDefaultMessage函數將返回一個缺省的內容,如果需要傳遞自己的內容才傳遞,這個缺省值就變成了動態計算的。
4.注意事項
在使用Javascript函數參數缺省值時,我們需要注意一些問題,以避免踩到坑。
4.1 參數的默認值為undefined不會生效
如果函數參數的默認值設為undefined,在函數調用時不傳值,默認值將不會生效,例如:
```
function func(a, b = 3, c = undefined, d = 4) {
console.log(a, b, c, d);
}
func(1, undefined); // 1 3 undefined 4
```
這個例子中,c參數的默認值設置為undefined,但是在函數調用時不傳值,c參數并沒有采用默認值。如果要采用默認值,必須傳遞undefined作為占位符。
4.2 參數默認值不會影響arguments對象
arguments數組包含函數參數的值,但不包含缺省值。例如:
```
function test(a, b = 3, c = 4) {
console.log(arguments[0], arguments[1], arguments[2]);
}
test(1); // 1 undefined undefined
test(1, 2); // 1 2 undefined
test(1, 2, 3); // 1 2 3
```
如上例子,test函數的第二個參數缺省值為3,當傳入一個參數時,第二個參數并沒有采用缺省值,并且在arguments變量中也沒有存在,只有一個值。因此,arguments的下標不一定等于函數定義時的形參名。
4.3 構造函數的獨特性
在Javascript中使用構造函數創建對象實例時,如果使用了缺省的形參,當創建多個對象時缺省形參的值會被共享。例如:
```
function Person(name, age = 18) {
this.name = name;
this.age = age;
}
let p1 = new Person('Tom');
let p2 = new Person('Mary');
console.log(p1.age === p2.age); // true
```
在這個例子中,我們創建了兩個Person實例,其中只傳遞了一個參數,沒有傳第二個參數,此時第二個參數應該采用缺省值18,但是我們發現p1和p2的年齡都等于18。這是因為缺省值是被共享的。
為了避免這個問題,我們需要使用類似下面的方式:
```
function Person(name, age) {
this.name = name;
this.age = age === undefined ? 18 : age;
}
let p1 = new Person('Tom');
let p2 = new Person('Mary');
console.log(p1.age === p2.age); // false
```
在這個例子中,我們手動判斷是否傳遞了第二個參數,如果沒有傳入就采用默認值。
總之,在使用Javascript的函數參數缺省值時,我們需要考慮各種不同的情況,并且小心使用它們,以避免引入新的bug。但總體來講,這個特性是非常有用的,可以提高編碼效率和代碼可讀性。
網站導航
- zblogPHP模板zbpkf
- zblog免費模板zblogfree
- zblog模板學習zblogxuexi
- zblogPHP仿站zbpfang