JavaScript中如何通過arguments對象實現(xiàn)對象的重載
更新時間:2014年05月12日 10:38:23 作者:
js 中不存在函數(shù)的重載,但卻可以通過arguments對象實現(xiàn)對象的重載,下面有個不錯的示例,大家可以參考下
復制代碼 代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<script type="text/javascript">
/*
*1.js 中不存在函數(shù)的重載
2.js函數(shù)定義時候的形參個數(shù),和執(zhí)行時候時,傳遞的實參的個數(shù)可以不一樣。
3.js執(zhí)行時候,會將真實的參數(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:因為調(diào)用的時后定義的兩個參數(shù)的函數(shù)
//也就是雖然有var的聲明,但是javascript中只要變量名稱相同,后定義的就會覆蓋
//之前定義的=======得出的結(jié)論就是js中不存在函數(shù)的重載。
//-------------------用arguments對象模擬方法的重載-----
//-依據(jù)不同的參數(shù)個數(shù),調(diào)用不同的代碼塊,最多25個參數(shù)
function addNum(){
alert(arguments.length);
for(var x=0;x<arguments.length;x++){
alert(arguments[x]);
//這個對象只能愛函數(shù)體內(nèi)
}
if(arguments.length==1){
return arguments[0]+10;
}else if(arguments.length==2){
return arguments[0]+arguments[1];
}else{
return "參數(shù)錯誤,請核對";
}
}
var value=addNum(10,20,30);
alert("函數(shù)的返回值:"+value);//結(jié)果value的值就是:"參數(shù)錯誤,請核對"
//事實上,是通過參數(shù)的判斷,去實現(xiàn)調(diào)用不同的函數(shù)功能,并且返回不同的值;這樣做類似的實現(xiàn)了java中的重載
//但是本質(zhì)上,js中是沒有重載的,相同的變量,在不同的位置出現(xiàn),若賦值后,必然會覆蓋前面聲明的變量。當然
//這里面排除掉函數(shù)內(nèi)部的量和函數(shù)外部變量的這一種關(guān)系。
</script>
</head>
<body>
</body>
</html>
相關(guān)文章
鼠標拖動改變DIV等網(wǎng)頁元素的大小的實現(xiàn)方法
下面小編就為大家?guī)硪黄髽送蟿痈淖僁IV等網(wǎng)頁元素的大小的實現(xiàn)方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
通過location.replace禁止瀏覽器后退防止重復提交
如果用戶重復提交事件,然后又后退,這樣可能會對某些數(shù)據(jù)產(chǎn)生災難性的問題。所以今天就向大家介紹一種通過location.replace禁止瀏覽器后退按鈕的方法2014-09-09
使用layui+ajax實現(xiàn)簡單的菜單權(quán)限管理及排序的方法
今天小編就為大家分享一篇使用layui+ajax實現(xiàn)簡單的菜單權(quán)限管理及排序的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
JavaScript中的appendChild()方法示例詳解
這篇文章主要介紹了JavaScript中的appendChild()方法,appendChild()方法是向節(jié)點添加最后一個子節(jié)點,也可以使用此方法從一個元素向另一個元素移動元素,本文結(jié)合實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2023-10-10
JavaScript鼠標拖動事件監(jiān)聽使用方法以及實例效果演示
最近工作中遇到了鼠標拖動事件監(jiān)聽的相關(guān)需求,所以下面這篇文章主要給大家介紹了關(guān)于JavaScript鼠標拖動事件監(jiān)聽使用方法以及實例效果演示的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-05-05
流量統(tǒng)計器如何鑒別C#:WebBrowser中偽造referer
這篇文章主要介紹了流量統(tǒng)計器如何鑒別C#:WebBrowser中偽造referer,需要的朋友可以參考下2015-01-01

