W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
JavaScript 函數(shù)對(duì)參數(shù)的值(arguments)沒(méi)有進(jìn)行任何的檢查。
JavaScript 函數(shù)參數(shù)與大多數(shù)其他語(yǔ)言的函數(shù)參數(shù)的區(qū)別在于:它不會(huì)關(guān)注有多少個(gè)參數(shù)被傳遞,不關(guān)注傳遞的參數(shù)的數(shù)據(jù)類型。
在先前的教程中,我們已經(jīng)學(xué)習(xí)了函數(shù)的顯式參數(shù):
函數(shù)顯式參數(shù)在函數(shù)定義時(shí)列出。
函數(shù)隱藏參數(shù)(arguments)在函數(shù)調(diào)用時(shí)傳遞給函數(shù)真正的值。
JavaScript 函數(shù)定義時(shí)參數(shù)沒(méi)有指定數(shù)據(jù)類型。
JavaScript 函數(shù)對(duì)隱藏參數(shù)(arguments)沒(méi)有進(jìn)行檢測(cè)。
JavaScript 函數(shù)對(duì)隱藏參數(shù)(arguments)的個(gè)數(shù)沒(méi)有進(jìn)行檢測(cè)。
如果函數(shù)在調(diào)用時(shí)缺少參數(shù),參數(shù)會(huì)默認(rèn)設(shè)置為: undefined
有時(shí)這是可以接受的,但是建議最好為參數(shù)設(shè)置一個(gè)默認(rèn)值:
或者,更簡(jiǎn)單的方式:
如果y已經(jīng)定義 , y || 0返回 y, 因?yàn)?y 是 true, 否則返回 0, 因?yàn)?undefined 為 false。 |
如果函數(shù)調(diào)用時(shí)設(shè)置了過(guò)多的參數(shù),參數(shù)將無(wú)法被引用,因?yàn)闊o(wú)法找到對(duì)應(yīng)的參數(shù)名。 只能使用 arguments 對(duì)象來(lái)調(diào)用。
JavaScript 函數(shù)有個(gè)內(nèi)置的對(duì)象 arguments 對(duì)象.
argument 對(duì)象包含了函數(shù)調(diào)用的參數(shù)數(shù)組。
通過(guò)這種方式你可以很方便的找到最后一個(gè)參數(shù)的值:
x = findMax(1, 123, 500, 115, 44, 88);
function findMax() {
var i, max = arguments[0];
if(arguments.length < 2)return max;
for (i = 0; i < arguments.length; i++) {
if (arguments[i] > max) {
max = arguments[i];
}
}
return max;
}
或者創(chuàng)建一個(gè)函數(shù)用來(lái)統(tǒng)計(jì)所有數(shù)值的和:
在函數(shù)中調(diào)用的參數(shù)是函數(shù)的參數(shù)。
如果函數(shù)修改參數(shù)的值,將不會(huì)修改參數(shù)的初始值(在函數(shù)外定義)。
總結(jié):JavaScript函數(shù)傳值只是將參數(shù)的值傳入函數(shù),函數(shù)會(huì)另外配置內(nèi)存保存參數(shù)值,所以并不會(huì)改變?cè)瓍?shù)的值。
實(shí)例
var x = 1;
// 通過(guò)值傳遞參數(shù)
function myFunction(x) {
x++; //修改參數(shù)x的值,將不會(huì)修改在函數(shù)外定義的變量 x
console.log(x);
}
myFunction(x); // 2
console.log(x); // 1
在JavaScript中,可以引用對(duì)象的值。
因此我們?cè)诤瘮?shù)內(nèi)部修改對(duì)象的屬性就會(huì)修改其初始的值。
修改對(duì)象屬性可作用于函數(shù)外部(全局變量)。
實(shí)例
var obj = {x:1};
// 通過(guò)對(duì)象傳遞參數(shù)
function myFunction(obj) {
obj.x++; //修改參數(shù)對(duì)象obj.x的值,函數(shù)外定義的obj也將會(huì)被修改
console.log(obj.x);
}
myFunction(obj); // 2
console.log(obj.x); // 2
提示:你可以在本站的JavaScript編程實(shí)戰(zhàn)中練習(xí)使用JavaScript函數(shù)參數(shù)!
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: