Javascript 函數(shù)中的參數(shù)使用分析
更新時間:2010年03月27日 00:13:25 作者:
關于JS中的函數(shù),相信大家已經(jīng)很了解了,其中有些特性呢,感覺還是值得提一提的,下面就說說JS中的函數(shù)吧。
首先,在JS中函數(shù)也是一種標識符,可以將它賦值給新的變量,也可以通過這個變量來調(diào)用。這有點像C語言的函數(shù)指針,不過也不完全一樣,如下面的代碼:
function myfun() {
alert("funcation call");
}
var fun = myfun;
fun();
再有一個值得說一下的,就是JS中的函數(shù)的參數(shù)不一定是嚴格匹配的,通常的編程經(jīng)驗,比如有這樣一個函數(shù) fun(aa,bb),那么我們在調(diào)用這個函數(shù)的時候就應該給他傳遞兩個參數(shù)。但是在JS中,我們可以給他傳遞任意個參數(shù),1個,3個,等等,都可以。JS中的參數(shù)傳遞,不完全是按照函數(shù)聲明時指定的那些參數(shù),在每次調(diào)用函數(shù)的時候,都會有一個命名為arguments的數(shù)組,這個數(shù)組里面存儲了函數(shù)調(diào)用時,傳遞進來的所有參數(shù),有了它,我們甚至可以不再函數(shù)聲明時指定形式參數(shù),如下代碼:
function args() {
if (arguments[0] != undefined) {
alert(arguments[0]);
}
}
args(); //什么也不輸出
args("hehe"); //彈出參數(shù)值
如上所示,arguments數(shù)組的每個下標,從0開始一次對應著傳遞進來的每個參數(shù),如果指定位置沒有參數(shù),那么他就會是undefined,
我們可以使用arguments.length來判斷傳遞進來的參數(shù)個數(shù),這種方式有時候會很有用,比如,我們可以利用這個特性來模擬C語言的printf函數(shù):
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"));
上面的代碼,簡單實現(xiàn)了格式化輸出的基本功能,當然,有興趣的話,還可以把它做得更好 ,最后再說一個吧,arguments還有個callee屬性,它代表了當前被調(diào)的函數(shù),這個屬性值某些情況下還是有點用處的??紤]如下代碼:
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
這是一個遞歸求和的函數(shù),mysum一開始和sum是同樣的函數(shù),如果在程序執(zhí)行過程中sum函數(shù)體被改變了,再調(diào)用mysum的結果就會不同,如果將函數(shù)改成這樣,就不會出現(xiàn)這樣的問題啦~
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都會指向當前的被調(diào)函數(shù),在用JS寫遞歸的時候,這點還是有必要注意一下的,雖然一般不
會出現(xiàn)這種錯誤,但是如果出了是不太容易發(fā)現(xiàn)原因的,會浪費不少時間。
復制代碼 代碼如下:
function myfun() {
alert("funcation call");
}
var fun = myfun;
fun();
再有一個值得說一下的,就是JS中的函數(shù)的參數(shù)不一定是嚴格匹配的,通常的編程經(jīng)驗,比如有這樣一個函數(shù) fun(aa,bb),那么我們在調(diào)用這個函數(shù)的時候就應該給他傳遞兩個參數(shù)。但是在JS中,我們可以給他傳遞任意個參數(shù),1個,3個,等等,都可以。JS中的參數(shù)傳遞,不完全是按照函數(shù)聲明時指定的那些參數(shù),在每次調(diào)用函數(shù)的時候,都會有一個命名為arguments的數(shù)組,這個數(shù)組里面存儲了函數(shù)調(diào)用時,傳遞進來的所有參數(shù),有了它,我們甚至可以不再函數(shù)聲明時指定形式參數(shù),如下代碼:
復制代碼 代碼如下:
function args() {
if (arguments[0] != undefined) {
alert(arguments[0]);
}
}
args(); //什么也不輸出
args("hehe"); //彈出參數(shù)值
如上所示,arguments數(shù)組的每個下標,從0開始一次對應著傳遞進來的每個參數(shù),如果指定位置沒有參數(shù),那么他就會是undefined,
我們可以使用arguments.length來判斷傳遞進來的參數(shù)個數(shù),這種方式有時候會很有用,比如,我們可以利用這個特性來模擬C語言的printf函數(shù):
復制代碼 代碼如下:
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"));
上面的代碼,簡單實現(xiàn)了格式化輸出的基本功能,當然,有興趣的話,還可以把它做得更好 ,最后再說一個吧,arguments還有個callee屬性,它代表了當前被調(diào)的函數(shù),這個屬性值某些情況下還是有點用處的??紤]如下代碼:
復制代碼 代碼如下:
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
這是一個遞歸求和的函數(shù),mysum一開始和sum是同樣的函數(shù),如果在程序執(zhí)行過程中sum函數(shù)體被改變了,再調(diào)用mysum的結果就會不同,如果將函數(shù)改成這樣,就不會出現(xiàn)這樣的問題啦~
復制代碼 代碼如下:
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都會指向當前的被調(diào)函數(shù),在用JS寫遞歸的時候,這點還是有必要注意一下的,雖然一般不
會出現(xiàn)這種錯誤,但是如果出了是不太容易發(fā)現(xiàn)原因的,會浪費不少時間。
您可能感興趣的文章:
- JS request函數(shù) 用來獲取url參數(shù)
- javascript獲取函數(shù)名稱、函數(shù)參數(shù)、對象屬性名稱的代碼實例
- JS中Date日期函數(shù)中的參數(shù)使用介紹
- js中對函數(shù)設置默認參數(shù)值的3種方法
- javascript 獲取url參數(shù)和script標簽中獲取url參數(shù)函數(shù)代碼
- JavaScript 事件屬性綁定帶參數(shù)的函數(shù)
- 一個JavaScript函數(shù)把URL參數(shù)解析成Json對象
- javascript自定義函數(shù)參數(shù)傳遞為字符串格式
- javascript arguments 傳遞給函數(shù)的隱含參數(shù)
- JS與PHP向函數(shù)傳遞可變參數(shù)的區(qū)別實例代碼
- JS函數(shù)多個參數(shù)默認值指定方法分析
相關文章
微信小程序五子棋游戲的悔棋實現(xiàn)方法【附demo源碼下載】
這篇文章主要介紹了微信小程序五子棋游戲的悔棋實現(xiàn)方法,結合實例形式分析了微信小程序中悔棋的原理與相關實現(xiàn)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2019-02-02js 關鍵詞高亮(根據(jù)ID/tag高亮關鍵字)案例介紹
關鍵詞高亮在開發(fā)中會帶來很多的方便,關鍵詞高亮包括:根據(jù)ID高亮關鍵字/根據(jù)Tag名高亮關鍵字等等,感興趣的朋友可以了解下,希望本文對你有所幫助2013-01-01Bootstrap源碼解讀網(wǎng)格系統(tǒng)(3)
這篇文章主要源碼解讀了Bootstrap網(wǎng)格系統(tǒng),介紹了Bootstrap網(wǎng)格系統(tǒng)的工作原理具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12JavaScript定義函數(shù)的三種實現(xiàn)方法
這篇文章主要介紹了JavaScript定義函數(shù)的三種實現(xiàn)方法的相關資料,希望通過本文大家能夠掌握三種定義函數(shù)的方法,需要的朋友可以參考下2017-09-09微信小程序 JS動態(tài)修改樣式的實現(xiàn)代碼
這篇文章主要介紹了微信小程序 JS動態(tài)修改樣式的實現(xiàn)代碼,原理是綁定數(shù)據(jù),然后動態(tài)的修改數(shù)據(jù),從而實現(xiàn)動態(tài)樣式的改變而已,需要的朋友可以參考下2017-02-02js調(diào)用webservice構造SOAP進行身份驗證
這篇文章主要介紹了js調(diào)用webservice構造SOAP進行身份驗證的相關資料,需要的朋友可以參考下2016-04-04