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

