电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

JavaScript面向對象三個基本特征實例詳解【封裝、繼承與多態】

瀏覽:120日期:2023-10-30 18:09:34

本文實例講述了JavaScript面向對象三個基本特征。分享給大家供大家參考,具體如下:

了解過面向對象的同學應該都知道,面向對象三個基本特征是:封裝、繼承、多態,但是對于這三個詞具體可能不太了解。對于前端來講接觸最多的可能就是封裝與繼承,對于多態來說可能就不是那么了解了。

封裝

在說封裝之先了解一下封裝到底是什么?

什么是封裝

封裝:將對象運行所需的資源封裝在程序對象中——基本上,是方法和數據。對象是“公布其接口”。其他附加到這些接口上的對象不需要關心對象實現的方法即可使用這個對象。這個概念就是“不要告訴我你是怎么做的,只要做就可以了。”對象可以看作是一個自我包含的原子。對象接口包括了公共的方法和初始化數據。(節選自百度百科)

我對于封裝的理解,可能還有一個步驟就是抽離,首先你要清楚在一個對代碼中你應該抽離那些屬性方法,有了這些為基礎才能更好的做好封裝。

封裝無非就是其屬性和方法封裝。

類:封裝對象的屬性和行為 方法:封裝具體邏輯功能 訪問封裝:訪問修飾封裝無非就是對其訪問權限進行封裝

class Employees { constructor(name,age){ this.name = name; this.age = age; } getInfo(){ let {name,age} = this; return {name,age}; } static seyHi(){ console.log('Hi'); }}let lisi = new Employees('Aaron',18);lisi.seyHi(); // lisi.seyHi is not a functionlisi.getInfo(); // {name: 'Aaron', age: 18}Employees.seyHi(); // Hi

在Employees中抽出的公共屬性有name,age,公共方法有getInfo,seyHi,然而getInfo與seyHi所不同的是seyHi使用了static修飾符,改變其為靜態方法,seyHi只屬于Employees這個類。然而getInfo方法則是屬于實例的。

這里使用了static對seyHi方法對其進行了訪問權限的封裝。

再舉一個例子。

Promise.then() // Promise.then is not a functionlet p1 = new Promise(() => {})p1.then(); // Promise {<pending>}Promise.all([1]); // Promise {<resolved>: Array(1)}

從上面的代碼中可以看出Promise也使用了static對其方法的訪問權限進行了封裝。

繼承

繼承:說到繼承并不太陌生,繼承可以使得子類具有父類的各種的公有屬性和公有方法。而不需要再次編寫相同的代碼。在令子類別繼承父類別的同時,可以重新定義某些屬性,并重寫某些方法,即覆蓋父類別的原有屬性和方法,使其獲得與父類別不同的功能。(節選自百度百科)

子類繼承父類后,子類具有父類屬性和方法,然而也同樣具備自己所獨有的屬性和方法,也就是說,子類的功能要比父類多或相同,不會比父類少。

class Employees { constructor(name){ this.name = name; } getName(){ console.log(this.name) } static seyHi(){ console.log('Hi'); }}class Java extends Employees{ constructor(name){ super(name); } work(){ console.log('做后臺工作'); }}let java = new Java('Aaron');java.getName();java.work();// java.seyHi(); // java.seyHi is not a function

從上面的例子可以看出繼承不會繼承父類的靜態方法,只會繼承父類的公有屬性與方法。這一點需要注意。

子類繼承之后既擁有了getName方法,同樣也擁有自己的worker方法。

多態

多態:按字面的意思就是“多種狀態”,允許將子類類型的指針賦值給父類類型的指針。(節選自百度百科)

說白了多態就是相同的事物,一個接口,多種實現,同時在最初的程序設定時,有可能會根據程序需求的不同,而不確定哪個函數實現,通過多態不需要修改源代碼,就可以實現一個接口多種解決方案。

多態的表現形式重寫與重載。

什么是重寫

重寫:子類可繼承父類中的方法,而不需要重新編寫相同的方法。但有時子類并不想原封不動地繼承父類的方法,而是想作一定的修改,這就需要采用方法的重寫。方法重寫又稱方法覆蓋。(節選自百度百科)

class Employees { constructor(name){ this.name = name; } seyHello(){ console.log('Hello') } getName(){ console.log(this.name); }}class Java extends Employees{ constructor(name){ super(name); } seyHello(){ console.log(`Hello,我的名字是${this.name},我是做Java工作的。`) }}const employees = new Employees('Aaron');const java = new Java('Leo');employees.seyHello(); // Hellojava.seyHello(); // Hello,我的名字是Leo,我是做Java工作的。employees.getName(); // Aaronjava.getName(); // Leo

通過上面的代碼可以看出Java繼承了Employees,然而子類與父類中都存在seyHello方法,為了滿足不同的需求子類繼承父類之后重寫了seyHello方法。所以在調用的時候會得到不同的結果。既然子類繼承了父類,子類也同樣擁有父類的getName方法。

什么是重載

重載就是函數或者方法有相同的名稱,但是參數列表不相同的情形,這樣的同名不同參數的函數或者方法之間,互相稱之為重載函數或者方法。(節選自百度百科)

class Employees { constructor(arg){ let obj = null; switch(typeof arg) { case 'string': obj = new StringEmployees(arg); break; case 'object': obj = new ObjEmployees(ObjEmployees); break; case 'number':obj = new NumberEmployees(ObjEmployees);break; } return obj; }}class ObjEmployees { constructor(arg){ console.log('ObjEmployees') }}class StringEmployees { constructor(arg){ console.log('StringEmployees') }}class NumberEmployees { constructor(arg){ console.log('NumberEmployees') }}new Employees({}) // ObjEmployeesnew Employees('123456') // StringEmployeesnew Employees(987654) // NumberEmployees

因為JavaScript是沒有重載的概念的所以要自己編寫邏輯完成重載。

在上面的代碼中定義了Employees,ObjEmployees,StringEmployees,NumberEmployees類,在實例化Employees的時候在constructor里面進行了判斷,根據參數的不同返回不同的對應的類。

這樣完成了一個簡單的類重載。

總結 封裝可以隱藏實現細節,使得代碼模塊化; 繼承可以擴展已存在的代碼模塊(類),它們的目的都是為了——代碼重用。 多態就是相同的事物,調用其相同的方法,參數也相同時,但表現的行為卻不同。多態分為兩種,一種是行為多態與對象的多態。

在編程的是多多運用這個寫思想對其編程時很有用的,能夠使你的代碼達到高復用以及可維護。

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 合肥注册公司|合肥代办营业执照、2024注册公司流程 | 密封圈_泛塞封_格莱圈-[东莞市国昊密封圈科技有限公司]专注密封圈定制生产厂家 | 天津市能谱科技有限公司-专业的红外光谱仪_红外测油仪_紫外测油仪_红外制样附件_傅里叶红外光谱技术生产服务厂商 | 液压压力机,液压折弯机,液压剪板机,模锻液压机-鲁南新力机床有限公司 | 二手色谱仪器,十万分之一分析天平,蒸发光检测器,电位滴定仪-湖北捷岛科学仪器有限公司 | 半自动预灌装机,卡式瓶灌装机,注射器灌装机,给药器灌装机,大输液灌装机,西林瓶灌装机-长沙一星制药机械有限公司 | 杰福伦_磁致伸缩位移传感器_线性位移传感器-意大利GEFRAN杰福伦-河南赉威液压科技有限公司 | 东莞动力锂电池保护板_BMS智能软件保护板_锂电池主动均衡保护板-东莞市倡芯电子科技有限公司 | 砍排机-锯骨机-冻肉切丁机-熟肉切片机-预制菜生产线一站式服务厂商 - 广州市祥九瑞盈机械设备有限公司 | 六自由度平台_六自由度运动平台_三自由度摇摆台—南京全控科技 | 北京四合院出租,北京四合院出售,北京平房买卖 - 顺益兴四合院 | 山楂片_雪花_迷你山楂片_山楂条饼厂家-青州市丰源食品厂 | 烟台螺纹,烟台H型钢,烟台钢材,烟台角钢-烟台市正丰金属材料有限公司 | 金属切削液-脱水防锈油-电火花机油-抗磨液压油-深圳市雨辰宏业科技发展有限公司 | LCD3D打印机|教育|桌面|光固化|FDM3D打印机|3D打印设备-广州造维科技有限公司 | 小区健身器材_户外健身器材_室外健身器材_公园健身路径-沧州浩然体育器材有限公司 | 粉末冶金注射成型厂家|MIM厂家|粉末冶金齿轮|MIM零件-深圳市新泰兴精密科技 | 天长市晶耀仪表有限公司 | 神超官网_焊接圆锯片_高速钢锯片_硬质合金锯片_浙江神超锯业制造有限公司 | 拖鞋定制厂家-品牌拖鞋代加工厂-振扬实业中国高端拖鞋大型制造商 | 柴油机_柴油发电机_厂家_品牌-江苏卡得城仕发动机有限公司 | 北京租车公司_汽车/客车/班车/大巴车租赁_商务会议/展会用车/旅游大巴出租_北京桐顺创业租车公司 | 阿米巴企业经营-阿米巴咨询管理-阿米巴企业培训-广东键锋企业管理咨询有限公司 | 【直乐】河北石家庄脊柱侧弯医院_治疗椎间盘突出哪家医院好_骨科脊柱外科专业医院_治疗抽动症/关节病骨伤权威医院|排行-直乐矫形中医医院 | 防水试验机_防水测试设备_防水试验装置_淋雨试验箱-广州岳信试验设备有限公司 | 视觉检测设备_自动化检测设备_CCD视觉检测机_外观缺陷检测-瑞智光电 | 药品/药物稳定性试验考察箱-埃里森仪器设备(上海)有限公司 | 台湾阳明固态继电器-奥托尼克斯光电传感器-接近开关-温控器-光纤传感器-编码器一级代理商江苏用之宜电气 | 短信营销平台_短信群发平台_106短信发送平台-河南路尚 | 商用绞肉机-熟肉切片机-冻肉切丁机-猪肉开条机 - 广州市正盈机械设备有限公司 | 飞行者联盟-飞机模拟机_无人机_低空经济_航空技术交流平台 | 南京展台搭建-南京展会设计-南京展览设计公司-南京展厅展示设计-南京汇雅展览工程有限公司 | 礼仪庆典公司,礼仪策划公司,庆典公司,演出公司,演艺公司,年会酒会,生日寿宴,动工仪式,开工仪式,奠基典礼,商务会议,竣工落成,乔迁揭牌,签约启动-东莞市开门红文化传媒有限公司 | 扬子叉车厂家_升降平台_电动搬运车|堆高车-扬子仓储叉车官网 | 哈尔滨京科脑康神经内科医院-哈尔滨治疗头痛医院-哈尔滨治疗癫痫康复医院 | 无尘烘箱_洁净烤箱_真空无氧烤箱_半导体烤箱_电子防潮柜-深圳市怡和兴机电 | 合同书格式和范文_合同书样本模板_电子版合同,找范文吧 | 百度爱采购运营研究社社群-店铺托管-爱采购代运营-良言多米网络公司 | 酒万铺-酒水招商-酒水代理 | 根系分析仪,大米外观品质检测仪,考种仪,藻类鉴定计数仪,叶面积仪,菌落计数仪,抑菌圈测量仪,抗生素效价测定仪,植物表型仪,冠层分析仪-杭州万深检测仪器网 | 【同风运车官网】一站式汽车托运服务平台,验车满意再付款 |