js中實現(xiàn)多態(tài)采用和繼承類似的方法
多態(tài)的實現(xiàn)可以采用和繼承類似的方法。首先定義一個抽象類,其中調(diào)用一些虛方法,虛方法在抽象類中沒用定義,而是通過其具體的實現(xiàn)類來實現(xiàn)。
如下面的例子:
Object.extend=function(destination,source){ for(property in source){ destination[property]=source[property]; } return destination; } //定義一個抽象基類base,無構造函數(shù) function base(){}; base.prototype={ initialize:function(){ this.oninit();//調(diào)用了一個虛方法 } } function SubClassA(){ //構造函數(shù) } SubClassA.prototype=Object.extend({ propInSubClassA:"propInSubClassA", oninit:function(){ alert(this.propInSubClassA); } },base.prototype); function SubClassB(){ //構造函數(shù) } SubClassB.prototype=Object.extend({ propInSubClassB:"propInSubClassB", oninit:function(){ alert(this.propInSubClassB); } },base.prototype); var objA=new SubClassA(); objA.initialize();//輸出"propInSubClassA" var objB=new SubClassB(); objB.initialize();//輸出"propInSubClassB"
首先定義了一個抽象基類base,在base類的initialize方法中調(diào)用了oninit方法,但是基類中并沒用oninit方法的實現(xiàn)或者聲明。SubClassA和SubClassB類繼承自base類,并且分別采用了不同的方式對oninit方法進行實現(xiàn)。
相關文章
JavaScript?ECMAScript?6(ES2015~ES2022)所有新特性總結
這篇文章主要介紹了JavaScript?ECMAScript?6(ES2015~ES2022)所有新特性總結,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-07-07javascript實現(xiàn)上傳圖片并預覽的效果實現(xiàn)代碼
圖片上傳預覽,就是在使用文件選擇框選擇了文件之后就可以在頁面上看見圖片的效果,關于這個效果我一直認為是無法做到的2011-04-04JavaScript的級聯(lián)函數(shù)用法簡單示例【鏈式調(diào)用】
這篇文章主要介紹了JavaScript的級聯(lián)函數(shù)用法,結合簡單實例形式分析了javascript鏈式調(diào)用具體定義及使用方法,需要的朋友可以參考下2019-03-03IE6、IE7中setAttribute不支持class/for/rowspan/colspan等屬性
IE6、IE7中setAttribute不支持class/for/rowspan/colspan等屬性的說明,需要的朋友可以參考下。2011-08-08