成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

面向?qū)ο笾齻€基本特征(JavaScript)

開發(fā) 前端
了解過面向?qū)ο蟮耐瑢W(xué)應(yīng)該都知道,面向?qū)ο笕齻€基本特征是:封裝、繼承、多態(tài),但是對于這三個詞具體可能不太了解。對于前端來講接觸最多的可能就是封裝與繼承,對于多態(tài)來說可能就不是那么了解了。

 

面向?qū)ο笾齻€基本特征(JavaScript)

了解過面向?qū)ο蟮耐瑢W(xué)應(yīng)該都知道,面向?qū)ο笕齻€基本特征是:封裝、繼承、多態(tài),但是對于這三個詞具體可能不太了解。對于前端來講接觸最多的可能就是封裝繼承,對于多態(tài)來說可能就不是那么了解了。

封裝

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

什么是封裝

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

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

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

  1. 類:封裝對象的屬性和行為
  2. 方法:封裝具體邏輯功能
  3. 訪問封裝:訪問修飾封裝無非就是對其訪問權(quán)限進行封裝
  1. class Employees { 
  2.     constructor(name,age){ 
  3.         this.name = name
  4.         this.age = age; 
  5.     } 
  6.     getInfo(){ 
  7.         let {name,age} = this; 
  8.         return {name,age}; 
  9.     } 
  10.     static seyHi(){ 
  11.         console.log("Hi");    
  12.     } 
  13.  
  14. let lisi = new Employees("Aaron",18); 
  15. lisi.seyHi();   // lisi.seyHi is not a function 
  16. lisi.getInfo();  // {name"Aaron", age: 18} 
  17. Employees.seyHi();  // Hi 

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

這里使用了staticseyHi方法對其進行了訪問權(quán)限的封裝。

再舉一個例子。

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

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

繼承

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

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

  1. class Employees { 
  2.     constructor(name){ 
  3.         this.name = name
  4.     } 
  5.     getName(){ 
  6.         console.log(this.name
  7.     } 
  8.     static seyHi(){ 
  9.         console.log("Hi");    
  10.     } 
  11. class Java extends Employees{ 
  12.     constructor(name){ 
  13.         super(name); 
  14.     } 
  15.     work(){ 
  16.         console.log("做后臺工作"); 
  17.     } 
  18. let java = new Java("Aaron"); 
  19. java.getName(); 
  20. java.work(); 
  21. // java.seyHi();    //  java.seyHi is not a function 

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

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

多態(tài)

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

說白了多態(tài)就是相同的事物,調(diào)用其相同的方法,參數(shù)也相同時,但表現(xiàn)的行為卻不同。多態(tài)分為兩種,一種是行為多態(tài)與對象的多態(tài)。

多態(tài)的表現(xiàn)形式重寫與重載。

什么是重寫

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

  1. class Employees { 
  2.     constructor(name){ 
  3.         this.name = name
  4.     } 
  5.     seyHello(){ 
  6.         console.log("Hello"
  7.     } 
  8.     getName(){ 
  9.         console.log(this.name); 
  10.     } 
  11. class Java extends Employees{ 
  12.     constructor(name){ 
  13.         super(name); 
  14.     } 
  15.     seyHello(){ 
  16.         console.log(`Hello,我的名字是${this.name},我是做Java工作的。`) 
  17.     } 
  18. const employees = new Employees("Aaron"); 
  19. const java = new Java("Leo"); 
  20. employees.seyHello();   //  Hello 
  21. java.seyHello();    //  Hello,我的名字是Leo,我是做Java工作的。 
  22. employees.getName();    //  Aaron 
  23. java.getName(); //  Leo 

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

什么是重載

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

  1. class Employees { 
  2.     constructor(arg){ 
  3.         let obj = null
  4.         switch(typeof arg) 
  5.         { 
  6.             case "string"
  7.                   obj = new StringEmployees(arg); 
  8.                   break; 
  9.             case "object"
  10.                   obj = new ObjEmployees(ObjEmployees); 
  11.                   break; 
  12.             case "number"
  13.                 obj = new NumberEmployees(ObjEmployees); 
  14.                 break; 
  15.         } 
  16.         return obj; 
  17.     } 
  18. class ObjEmployees { 
  19.     constructor(arg){ 
  20.         console.log("ObjEmployees"
  21.     } 
  22. class StringEmployees { 
  23.     constructor(arg){ 
  24.         console.log("StringEmployees"
  25.     } 
  26. class NumberEmployees { 
  27.     constructor(arg){ 
  28.         console.log("NumberEmployees"
  29.     } 
  30. new Employees({})   // ObjEmployees 
  31. new Employees("123456") //  StringEmployees 
  32. new Employees(987654)   //  NumberEmployees 

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

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

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

總結(jié)

  1. 封裝可以隱藏實現(xiàn)細(xì)節(jié),使得代碼模塊化;
  2. 繼承可以擴展已存在的代碼模塊(類),它們的目的都是為了——代碼重用。
  3. 多態(tài)就是相同的事物,調(diào)用其相同的方法,參數(shù)也相同時,但表現(xiàn)的行為卻不同。多態(tài)分為兩種,一種是行為多態(tài)與對象的多態(tài)。

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

 

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2019-09-18 18:56:34

JavascriptOOP前端

2012-12-17 10:25:21

浪潮張東云數(shù)據(jù)中心

2021-06-15 15:20:15

APIWeb應(yīng)用軟件開發(fā)

2021-04-27 13:40:47

邊緣計算物聯(lián)網(wǎng)物聯(lián)網(wǎng)平臺

2011-06-14 10:35:15

性能優(yōu)化

2011-05-13 11:05:52

javascript

2011-07-04 10:08:57

云計算

2012-03-19 09:24:25

JavaScript

2011-05-25 11:15:02

Javascript繼承

2018-02-24 17:20:07

2018-07-16 16:10:03

前端JavaScript面向?qū)ο?/a>

2010-03-05 14:44:36

Python繼承

2012-01-17 09:34:52

JavaScript

2017-04-21 09:07:39

JavaScript對象編程

2023-03-16 11:04:00

CIO技術(shù)領(lǐng)導(dǎo)者

2010-04-21 15:10:14

Oracle數(shù)據(jù)類型

2009-07-03 17:01:30

JSP2JSP

2021-10-21 18:47:37

JavaScript面向對象

2012-02-27 09:30:22

JavaScript

2009-08-06 11:00:19

C#對象的使用
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: www.亚洲视频 | 天堂色| 国产综合久久久 | 久久精品一区二区三区四区 | 欧美日韩国产三级 | 国产精品久久久久久久久久 | 国产精品亚洲欧美日韩一区在线 | 激情毛片 | 欧美一级片中文字幕 | 精久久 | 成人看片在线观看 | 精品国产乱码久久久久久丨区2区 | 欧美伦理一区 | 成人综合一区二区 | 福利成人 | 亚洲1区| 日日骚视频 | 91精品在线观看入口 | 欧美一区二区三区的 | 国产色| 欧美激情视频一区二区三区在线播放 | 久久男人 | 看片天堂| 欧美一区二区在线播放 | 99在线资源 | 亚洲成人高清 | 久久免费精品视频 | 免费看爱爱视频 | 久久国产精品免费一区二区三区 | 亚洲va欧美va人人爽午夜 | av一区二区三区 | 成人在线观看欧美 | 成人免费视频一区 | 欧洲成人 | 伊人91在线| 久久精彩视频 | 成人免费共享视频 | 欧美一区在线视频 | 午夜欧美一区二区三区在线播放 | 日韩激情在线 | 在线日韩欧美 |