首頁 > web前端 > js教程 > 詳解JS函數重載_javascript技巧

詳解JS函數重載_javascript技巧

WBOY
發布: 2016-05-16 16:29:11
原創
1640 人瀏覽過

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

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

1.依參數個數重載

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

複製程式碼 程式碼如下:


2.依參數型別重載

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

typeof string number object function boolean object object
constructor String Number Object Function Boolean Array User Define

複製程式碼 程式碼如下:


小夥伴們是否理解了javascript函數重載的方法了呢,有疑問就留言吧

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板