JavaScript的arguments對象應(yīng)用示例
arguments 對象
在函數(shù)代碼中,使用特殊對象 arguments,開發(fā)者無需明確指出參數(shù)名,就能訪問它們。
例如,在函數(shù) sayHi() 中,第一個參數(shù)是 message。用 arguments[0] 也可以訪問這個值,即第一個參數(shù)的值(第一個參數(shù)位于位置 0,第二個參數(shù)位于位置 1,依此類推)。
因此,無需明確命名參數(shù),就可以重寫函數(shù):
function sayHi() { if (arguments[0] == "bye") { return; } alert(arguments[0]); }
檢測參數(shù)個數(shù)
還可以用 arguments 對象檢測函數(shù)的參數(shù)個數(shù),引用屬性 arguments.length 即可。
下面的代碼將輸出每次調(diào)用函數(shù)使用的參數(shù)個數(shù):
function howManyArgs() { alert(arguments.length); } howManyArgs("string", 45); howManyArgs(); howManyArgs(12);
上面這段代碼將依次顯示 "2"、"0" 和 "1"。
注釋:與其他程序設(shè)計語言不同,ECMAScript 不會驗(yàn)證傳遞給函數(shù)的參數(shù)個數(shù)是否等于函數(shù)定義的參數(shù)個數(shù)。開發(fā)者定義的函數(shù)都可以接受任意個數(shù)的參數(shù)(根據(jù) Netscape 的文檔,最多可接受 255 個),而不會引發(fā)任何錯誤。任何遺漏的參數(shù)都會以 undefined 傳遞給函數(shù),多余的函數(shù)將忽略。
模擬函數(shù)重載
用 arguments 對象判斷傳遞給函數(shù)的參數(shù)個數(shù),即可模擬函數(shù)重載:
function doAdd() { if(arguments.length == 1) { alert(arguments[0] + 5); } else if(arguments.length == 2) { alert(arguments[0] + arguments[1]); } }
doAdd(10); //輸出 "15"
doAdd(40, 20); //輸出 "60"
當(dāng)只有一個參數(shù)時,doAdd() 函數(shù)給參數(shù)加 5。如果有兩個參數(shù),則會把兩個參數(shù)相加,返回它們的和。所以,doAdd(10) 輸出的是 "15",而 doAdd(40, 20) 輸出的是 "60"。
雖然不如重載那么好,不過已足以避開 ECMAScript 的這種限制。
- javascript內(nèi)置對象arguments詳解
- js arguments對象應(yīng)用介紹
- Javascript中arguments對象詳解
- JavaScript中如何通過arguments對象實(shí)現(xiàn)對象的重載
- javaScript arguments 對象使用介紹
- Javascript學(xué)習(xí)筆記之函數(shù)篇(四):arguments 對象
- 跟我學(xué)習(xí)javascript的arguments對象
- JS中使用變量保存arguments對象的方法
- Javascript中的arguments對象
- Javascript中arguments對象的詳解與使用方法
相關(guān)文章
JavaScript基于setTimeout實(shí)現(xiàn)計數(shù)的方法
這篇文章主要介紹了JavaScript基于setTimeout實(shí)現(xiàn)計數(shù)的方法,涉及javascript中setTimeout方法的使用技巧,需要的朋友可以參考下2015-05-05JavaScript學(xué)習(xí)筆記之圖片庫案例分析
這篇文章主要介紹了JavaScript學(xué)習(xí)筆記之圖片庫案例,結(jié)合具體實(shí)例形式分析了javascript圖片庫相關(guān)的頁面元素動態(tài)操作實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-01-01vue組件中watch props根據(jù)v-if動態(tài)判斷并掛載DOM的問題
這篇文章主要介紹了vue組件中watch props根據(jù)v-if動態(tài)判斷并掛載DOM的問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-05-05你所不了解的javascript操作DOM的細(xì)節(jié)知識點(diǎn)(一)
這篇文章主要介紹了你所不了解的javascript操作DOM的細(xì)節(jié)知識點(diǎn)的相關(guān)資料,需要的朋友可以參考下2015-06-06基于JavaScript實(shí)現(xiàn)本地圖片預(yù)覽
這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)本地圖片預(yù)覽的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-02-02