Javascript 函數中的參數流量分析

來源:互聯網
上載者:User

首先,在JS中函數也是一種標識符,可以將它賦值給新的變數,也可以通過這個變數來調用。這有點像C語言的函數指標,不過也不完全一樣,如下面的代碼: 複製代碼 代碼如下:function myfun() {
alert("funcation call");
}
var fun = myfun;
fun();

  再有一個值得說一下的,就是JS中的函數的參數不一定是嚴格匹配的,通常的編程經驗,比如有這樣一個函數 fun(aa,bb),那麼我們在調用這個函數的時候就應該給他傳遞兩個參數。但是在JS中,我們可以給他傳遞任意個參數,1個,3個,等等,都可以。JS中的參數傳遞,不完全是按照函式宣告時指定的那些參數,在每次調用函數的時候,都會有一個命名為arguments的數組,這個數組裡面儲存了函數調用時,傳遞進來的所有參數,有了它,我們甚至可以不再函式宣告時指定形式參數,如下代碼: 複製代碼 代碼如下:function args() {
if (arguments[0] != undefined) {
alert(arguments[0]);
}
}
args(); //什麼也不輸出
args("hehe"); //彈出參數值

  如上所示,arguments數組的每個下標,從0開始一次對應著傳遞進來的每個參數,如果指定位置沒有參數,那麼他就會是undefined,
我們可以使用arguments.length來判斷傳遞進來的參數個數,這種方式有時候會很有用,比如,我們可以利用這個特性來類比C語言的printf函數: 複製代碼 代碼如下: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"));

  上面的代碼,簡單實現了格式化輸出的準系統,當然,有興趣的話,還可以把它做得更好 ,最後再說一個吧,arguments還有個callee屬性,它代表了當前被調的函數,這個屬性值某些情況下還是有點用處的。考慮如下代碼: 複製代碼 代碼如下: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

  這是一個遞迴求和的函數,mysum一開始和sum是同樣的函數,如果在程式執行過程中sum函數體被改變了,再調用mysum的結果就會不同,如果將函數改成這樣,就不會出現這樣的問題啦~ 複製代碼 代碼如下: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都會指向當前的被調函數,在用JS寫遞迴的時候,這點還是有必要注意一下的,雖然一般不
會出現這種錯誤,但是如果出了是不太容易發現原因的,會浪費不少時間。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.