JavaScript中如何通過arguments對(duì)象實(shí)現(xiàn)對(duì)象的重載
更新時(shí)間:2014年05月12日 10:38:23 作者:
js 中不存在函數(shù)的重載,但卻可以通過arguments對(duì)象實(shí)現(xiàn)對(duì)象的重載,下面有個(gè)不錯(cuò)的示例,大家可以參考下
復(fù)制代碼 代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<script type="text/javascript">
/*
*1.js 中不存在函數(shù)的重載
2.js函數(shù)定義時(shí)候的形參個(gè)數(shù),和執(zhí)行時(shí)候時(shí),傳遞的實(shí)參的個(gè)數(shù)可以不一樣。
3.js執(zhí)行時(shí)候,會(huì)將真實(shí)的參數(shù),封裝成組arguments
*/
function add(a){
return a+10;
}
var add=new Function("a","return a+10");
//alert(add(5));
function add(num1,num2){
return num1+num2;
}
var add=new Function("num1","num2","return num1+num2");
alert(add(5,6));
alert(add(5));//這樣調(diào)用的結(jié)果是NaN:因?yàn)檎{(diào)用的時(shí)后定義的兩個(gè)參數(shù)的函數(shù)
//也就是雖然有var的聲明,但是javascript中只要變量名稱相同,后定義的就會(huì)覆蓋
//之前定義的=======得出的結(jié)論就是js中不存在函數(shù)的重載。
//-------------------用arguments對(duì)象模擬方法的重載-----
//-依據(jù)不同的參數(shù)個(gè)數(shù),調(diào)用不同的代碼塊,最多25個(gè)參數(shù)
function addNum(){
alert(arguments.length);
for(var x=0;x<arguments.length;x++){
alert(arguments[x]);
//這個(gè)對(duì)象只能愛函數(shù)體內(nèi)
}
if(arguments.length==1){
return arguments[0]+10;
}else if(arguments.length==2){
return arguments[0]+arguments[1];
}else{
return "參數(shù)錯(cuò)誤,請(qǐng)核對(duì)";
}
}
var value=addNum(10,20,30);
alert("函數(shù)的返回值:"+value);//結(jié)果value的值就是:"參數(shù)錯(cuò)誤,請(qǐng)核對(duì)"
//事實(shí)上,是通過參數(shù)的判斷,去實(shí)現(xiàn)調(diào)用不同的函數(shù)功能,并且返回不同的值;這樣做類似的實(shí)現(xiàn)了java中的重載
//但是本質(zhì)上,js中是沒有重載的,相同的變量,在不同的位置出現(xiàn),若賦值后,必然會(huì)覆蓋前面聲明的變量。當(dāng)然
//這里面排除掉函數(shù)內(nèi)部的量和函數(shù)外部變量的這一種關(guān)系。
</script>
</head>
<body>
</body>
</html>
您可能感興趣的文章:
- javascript內(nèi)置對(duì)象arguments詳解
- js arguments對(duì)象應(yīng)用介紹
- Javascript中arguments對(duì)象的詳解與使用方法
- Javascript中的arguments對(duì)象
- Javascript中arguments對(duì)象詳解
- JS中使用變量保存arguments對(duì)象的方法
- 深入解析JavaScript中的arguments對(duì)象
- 跟我學(xué)習(xí)javascript的arguments對(duì)象
- Javascript學(xué)習(xí)筆記之函數(shù)篇(四):arguments 對(duì)象
- js中arguments對(duì)象的深入理解
相關(guān)文章
uniapp開發(fā)H5使用formData上傳文件解決方案
我們很多時(shí)候上傳文件就是使用FormData,然而uniapp默認(rèn)不支持FormData類型數(shù)據(jù)的上傳,下面這篇文章主要給大家介紹了關(guān)于uniapp開發(fā)H5使用formData上傳文件的相關(guān)資料,需要的朋友可以參考下2023-12-12微信小程序防止多次點(diǎn)擊跳轉(zhuǎn)和防止表單組件輸入內(nèi)容多次驗(yàn)證功能(函數(shù)防抖)
這篇文章主要介紹了微信小程序防止多次點(diǎn)擊跳轉(zhuǎn)和防止表單組件輸入內(nèi)容多次驗(yàn)證功能(函數(shù)防抖),需要的朋友可以參考下2019-09-09javascript canvas封裝動(dòng)態(tài)時(shí)鐘
這篇文章主要為大家詳細(xì)介紹了javascript canvas封裝動(dòng)態(tài)時(shí)鐘,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-09-09