本文實例講述了JavaScript多態與封裝。分享給大家供大家參考,具體如下:
編程語言按照數據類型可以分為靜態語言類型和動態語言類型兩大類。
優點:在編譯時就能發現類型不匹配的錯誤,編譯器可以幫助我們提前避免程序在運行期間可能發生的一些錯誤;在程序中明確規定了數據類型,編譯器可以針對這些信息對程序進行優化工作。
缺點:迫使程序員依照契約來編寫程序,為每個變量規定數據類型;類型的聲明也會增加更多的代碼,使得程序員難以專注于業務邏輯。
優點:編寫的代碼數量少,簡潔使得程序員可以更專注于業務邏輯。
缺點:無法保證變量的類型,在程序運行期間可能發生與類型有關的錯誤。
多態的思想實際上是:將"做什么"與"誰去做以及怎樣去做"分離開,也就是將"不變的事物"與"可能改變的事物"分離開,把不變的事物隔離出來,把可變的部分封裝起來。要實現這一點,歸根結底就是要消除類型之間的耦合關系。
多態的最根本的作用是:通過把程序化的條件分支語句轉化為對象的多態性,從而消除這些條件分支語句。
var student = { show: function() { console.log('我是學生'); }};var teacher = { show: function() { console.log('我是老師'); }};var showMe = function(type) { if (type == 'teacher') teacher.show(); else if (type == 'student') teacher.show();};showMe('teacher');showMe('student');問題:一旦需要增加新的type對應的show()方法,必須改動showMe()函數。
解決:把程序中相同的部分抽離出來。
var student = { show: function() { console.log('我是學生'); }};var teacher = { show: function() { console.log('我是老師'); }};var showMe = function(obj) { if (obj.show instanceof Function) obj.show();};showMe('teacher');showMe('student');若需要增加doctor類型對象,只需增加:
var doctor = { show: function() { console.log('我是醫生'); }};showMe(doctor);設計模式與多態:
絕大部分設計模式的實現都離不開多態性的思想。
封裝的目的是將信息隱藏。一般封裝指的是封裝數據和封裝實現,但廣義的封裝還包括封裝類型和封裝變化。
JavaScript沒有提供private、public、protected等關鍵字來實現不同的訪問權限,只能依賴變量的作用域來實現封裝特性,而且只能模擬出private、public兩種封裝性。
新聞熱點
疑難解答
圖片精選