欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Javascript 函數(shù)中的參數(shù)使用分析

 更新時(shí)間:2010年03月27日 00:13:25   作者:  
關(guān)于JS中的函數(shù),相信大家已經(jīng)很了解了,其中有些特性呢,感覺(jué)還是值得提一提的,下面就說(shuō)說(shuō)JS中的函數(shù)吧。
首先,在JS中函數(shù)也是一種標(biāo)識(shí)符,可以將它賦值給新的變量,也可以通過(guò)這個(gè)變量來(lái)調(diào)用。這有點(diǎn)像C語(yǔ)言的函數(shù)指針,不過(guò)也不完全一樣,如下面的代碼:
復(fù)制代碼 代碼如下:

function myfun() {
alert("funcation call");
}
var fun = myfun;
fun();

  再有一個(gè)值得說(shuō)一下的,就是JS中的函數(shù)的參數(shù)不一定是嚴(yán)格匹配的,通常的編程經(jīng)驗(yàn),比如有這樣一個(gè)函數(shù) fun(aa,bb),那么我們?cè)谡{(diào)用這個(gè)函數(shù)的時(shí)候就應(yīng)該給他傳遞兩個(gè)參數(shù)。但是在JS中,我們可以給他傳遞任意個(gè)參數(shù),1個(gè),3個(gè),等等,都可以。JS中的參數(shù)傳遞,不完全是按照函數(shù)聲明時(shí)指定的那些參數(shù),在每次調(diào)用函數(shù)的時(shí)候,都會(huì)有一個(gè)命名為arguments的數(shù)組,這個(gè)數(shù)組里面存儲(chǔ)了函數(shù)調(diào)用時(shí),傳遞進(jìn)來(lái)的所有參數(shù),有了它,我們甚至可以不再函數(shù)聲明時(shí)指定形式參數(shù),如下代碼:
復(fù)制代碼 代碼如下:

function args() {
if (arguments[0] != undefined) {
alert(arguments[0]);
}
}
args(); //什么也不輸出
args("hehe"); //彈出參數(shù)值

  如上所示,arguments數(shù)組的每個(gè)下標(biāo),從0開(kāi)始一次對(duì)應(yīng)著傳遞進(jìn)來(lái)的每個(gè)參數(shù),如果指定位置沒(méi)有參數(shù),那么他就會(huì)是undefined,
我們可以使用arguments.length來(lái)判斷傳遞進(jìn)來(lái)的參數(shù)個(gè)數(shù),這種方式有時(shí)候會(huì)很有用,比如,我們可以利用這個(gè)特性來(lái)模擬C語(yǔ)言的printf函數(shù):
復(fù)制代碼 代碼如下:

function format() {
if (arguments.length == 0) {
return "";
}
var formatter = arguments[0];
for (var i = 1; i < arguments.length; i++) {
formatter = formatter.replace(new RegExp("\\{"+(i-1)+"\\}","gm"), arguments[i]);
}
return formatter;
}
alert(format("Hello {0},this is the fetures of {1}!","world","javascript"));

  上面的代碼,簡(jiǎn)單實(shí)現(xiàn)了格式化輸出的基本功能,當(dāng)然,有興趣的話,還可以把它做得更好 ,最后再說(shuō)一個(gè)吧,arguments還有個(gè)callee屬性,它代表了當(dāng)前被調(diào)的函數(shù),這個(gè)屬性值某些情況下還是有點(diǎn)用處的。考慮如下代碼:
復(fù)制代碼 代碼如下:

function sum(num) {
if (num == 1) {
return num;
} else {
return num + sum(num - 1);
}
}
var mysum = sum;
alert(mysum(5)); //輸出 15
sum = function() { return 1; };
alert(mysum(5)); //輸出 6

  這是一個(gè)遞歸求和的函數(shù),mysum一開(kāi)始和sum是同樣的函數(shù),如果在程序執(zhí)行過(guò)程中sum函數(shù)體被改變了,再調(diào)用mysum的結(jié)果就會(huì)不同,如果將函數(shù)改成這樣,就不會(huì)出現(xiàn)這樣的問(wèn)題啦~
復(fù)制代碼 代碼如下:

function sum(num) {
if (num == 1) {
return num;
} else {
return num + arguments.callee(num - 1);
}
}
var mysum = sum;
alert(mysum(5)); //輸出 15
sum = function() { return 1; };
alert(mysum(5)); //輸出 15

  如上面這樣,不管外面的引用怎么改變callee都會(huì)指向當(dāng)前的被調(diào)函數(shù),在用JS寫(xiě)遞歸的時(shí)候,這點(diǎn)還是有必要注意一下的,雖然一般不
會(huì)出現(xiàn)這種錯(cuò)誤,但是如果出了是不太容易發(fā)現(xiàn)原因的,會(huì)浪費(fèi)不少時(shí)間。

相關(guān)文章

最新評(píng)論