Javascript中的arguments對象
在js中一切都是對象,連函數(shù)也是對象,函數(shù)名其實是引用函數(shù)定義對象的變量。
1、什么是arguments?
這個函數(shù)體內(nèi)的arguments非常特殊,實際上是所在函數(shù)的一個內(nèi)置類數(shù)組對象,可以用數(shù)組的[i]和.length。
2、有什么作用?
js語法不支持重載!但可用arguments對象模擬重載效果。
arguments對象:函數(shù)對象內(nèi),自動創(chuàng)建的專門接收所有參數(shù)值得類數(shù)組對象。
arguments[i]: 獲得傳入的下標為i的參數(shù)值
arguments.length: 獲得傳入的參數(shù)個數(shù)!
重載:
程序中可定義多個相同函數(shù)名,不同參數(shù)列表的函數(shù),
調(diào)用者不必區(qū)分每個函數(shù)的參數(shù),
執(zhí)行時,程序根據(jù)傳入的參數(shù)個數(shù),自動判斷選擇哪個函數(shù)執(zhí)行。
例子如下:
// 1、如果用戶傳入一個參數(shù),求平方 function sum(a){ console.log(a*a); } //如果用戶傳入兩個參數(shù),就求和 function sum(a,b){ console.log(a+b); } sum(4); //? sum(4,5); //?
上述例子中本意是想讓同名函數(shù)sum()根據(jù)參數(shù)不同輸出不同結(jié)果,但是sum是函數(shù)名字,本質(zhì)也是個變量,
第二個會覆蓋第一個,所以上述的正確輸出答案是:NaN,9.所以這樣顯然不可以。
如果用arguments,就簡單多了。
如下2個例子:
//2、 function calc(){ //如果用戶傳入一個參數(shù),求平方 if(arguments.length==1){ console.log(arguments[0]*arguments[0]); }else if(arguments.length==2){ //如果用戶傳入兩個參數(shù),就求和 console.log(arguments[0]+arguments[1]); } } calc(4); //16 calc(4,5); //9 /*3、無論用戶傳入幾個數(shù)字,都可以求和*/ function add(){ //arguments:[] //遍歷arguments中每個元素,并累加 for(var i=0,sum=0;i<arguments.length;sum+=arguments[i++]); return sum;//返回和 } console.log(add(1,2,3)); //6 console.log(add(1,2,3,4,5,6)); //21
這就是JS利用arguments重載的效果,簡單理解就是一個函數(shù)重復(fù)利用.
arguments.length是有實參決定,即函數(shù)調(diào)用時候里面的參數(shù)個數(shù)決定!
以上所述是小編給大家介紹的Javascript中的arguments對象的相關(guān)知識,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
js實現(xiàn)的點擊數(shù)量加一可操作數(shù)據(jù)庫
這篇文章主要介紹了js如何實現(xiàn)的點擊數(shù)量加一操作數(shù)據(jù)庫,需要的朋友可以參考下2014-05-05JavaScript從數(shù)組的indexOf()深入之Object的Property機制
這篇文章主要介紹了JavaScript從數(shù)組的indexOf()深入——Object的Property機制的相關(guān)資料,需要的朋友可以參考下2016-05-05JavaScript 異步調(diào)用框架 (Part 1 - 問題 & 場景)
在Ajax應(yīng)用中,調(diào)用XMLHttpRequest是很常見的情況。特別是以客戶端為中心的Ajax應(yīng)用,各種需要從服務(wù)器端獲取數(shù)據(jù)的操作都通過XHR異步調(diào)用完成。2009-08-08Javascript將字符串日期格式化為yyyy-mm-dd的方法
日期格式化相信對于大家來說再熟悉不過,最近工作中自己利用Javascript就寫了一個,現(xiàn)在將實現(xiàn)的代碼分享給大家,希望對有需要的朋友們能有所幫助,感興趣的朋友們下面來一起看看吧。2016-10-10JS實現(xiàn)單張或多張圖片持續(xù)無縫滾動的示例代碼
這篇文章主要介紹了JS實現(xiàn)單張或多張圖片持續(xù)無縫滾動效果,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-05-05擴展bootstrap的modal模態(tài)框-動態(tài)添加modal框-彈出多個modal框
這篇文章主要介紹了擴展bootstrap的modal模態(tài)框-動態(tài)添加modal框-彈出多個modal框,需要的朋友可以參考下2017-02-02