日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 前端技术 > javascript >内容正文

javascript

JS函数重载解决方案

發布時間:2025/4/16 javascript 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JS函数重载解决方案 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

JS的函數定義可以指定形式參數名稱,多多少少我們會以為js至少可以支持參數個數不同的方法重載,然而遺憾的是這僅僅是一個假象,js所有的參數都是以arguments傳遞過去的,這個參數類似于數組,在函數調用的時候,所有的實參都是保存在了這個數據結構里面,我們定義函數的時候所指定的形式參數其實是為這個數據結構里面的數據定義一個快捷的訪問方式。也就是說js所有的函數都是支持無限個參數的,加上數據類型是弱類型,那么JS的函數除了名稱就真的沒有方法區別了?

  辦法總是有的,我們可以利用JavaScript中的特殊對象arguments來模擬函數重載。用它來判斷傳入參數的個數或類型以區分重載。

1.根據參數個數重載

js判斷傳入參數數量可以用arguments.length這個屬性來判斷;

1 2 3 4 5 6 7 8 9 10 11 12 13 <script type="text/javascript"> function add() { ????if (arguments.length == 1) { ????????alert(arguments[0] + 10); ????} ????else if (arguments.length == 2) { ????????alert(arguments[0] + arguments[1]); ????} } //函數調用 add(10); add(10, 20); </script>

2.根據參數類型重載

判斷變量類型的3種方法:
1.用 typeof 語句判斷變量類型,typeof語句返回類型對應的字符串。
2.用 instanceof 語句判斷變量類型,instanceof語句返回true/false。
3.用 constructor 屬性判斷變量類型,這個屬性返回用來構造該變量的構造函數引用。
對照表:可以看出用 typeof 不能準確的判斷出具體的類型,所以我們用 constructor 來進行判斷。

typeofstringnumberobjectfunctionbooleanobjectobject
constructorStringNumberObjectFunctionBooleanArrayUser Define
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 <script type="text/javascript"> function add() { ????if (arguments.length == 0) return 0; ????var sum=0; ????for(var i=0; i<arguments.length; i++){ ????????if(arguments[i].constructor == Number){ ????????//或者改為:if(arguments[i] instanceof Number) ????????//或者改為:if(typeof(arguments[i])=="number") ????????sum += arguments[i]; ??????} ????} ????return sum; } //函數調用 alert(add(10)); alert(add(10,20)); </script>

轉載于:https://www.cnblogs.com/ranran/p/javascript_chongzai.html

總結

以上是生活随笔為你收集整理的JS函数重载解决方案的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。