亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript面向?qū)ο笕齻€(gè)基本特征實(shí)例詳解【封裝、繼承與多態(tài)】

 更新時(shí)間:2020年05月06日 11:36:36   作者:Aaron  
這篇文章主要介紹了JavaScript面向?qū)ο笕齻€(gè)基本特征,結(jié)合實(shí)例形式詳細(xì)分析了JavaScript面向?qū)ο笕齻€(gè)基本特征封裝、繼承與多態(tài)的概念、原理、用法與操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了JavaScript面向?qū)ο笕齻€(gè)基本特征。分享給大家供大家參考,具體如下:

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

封裝

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

什么是封裝

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

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

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

  1. 類:封裝對(duì)象的屬性和行為
  2. 方法:封裝具體邏輯功能
  3. 訪問封裝:訪問修飾封裝無非就是對(duì)其訪問權(quán)限進(jìn)行封裝
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 function
lisi.getInfo(); // {name: "Aaron", age: 18}
Employees.seyHi(); // Hi

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

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

再舉一個(gè)例子。

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

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

繼承

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

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

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("做后臺(tái)工作");
  }
}
let java = new Java("Aaron");
java.getName();
java.work();
// java.seyHi();  // java.seyHi is not a function

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

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

多態(tài)

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

說白了多態(tài)就是相同的事物,一個(gè)接口,多種實(shí)現(xiàn),同時(shí)在最初的程序設(shè)定時(shí),有可能會(huì)根據(jù)程序需求的不同,而不確定哪個(gè)函數(shù)實(shí)現(xiàn),通過多態(tài)不需要修改源代碼,就可以實(shí)現(xiàn)一個(gè)接口多種解決方案。

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

什么是重寫

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

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();  // Hello
java.seyHello();  // Hello,我的名字是Leo,我是做Java工作的。
employees.getName();  // Aaron
java.getName(); // Leo

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

什么是重載

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

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({})  // ObjEmployees
new Employees("123456") // StringEmployees
new Employees(987654)  // NumberEmployees

因?yàn)镴avaScript是沒有重載的概念的所以要自己編寫邏輯完成重載。

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

這樣完成了一個(gè)簡單的類重載。

總結(jié)

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

在編程的是多多運(yùn)用這個(gè)寫思想對(duì)其編程時(shí)很有用的,能夠使你的代碼達(dá)到高復(fù)用以及可維護(hù)。

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

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 利用JavaScript實(shí)現(xiàn)春節(jié)倒計(jì)時(shí)效果(移動(dòng)端和PC端)

    利用JavaScript實(shí)現(xiàn)春節(jié)倒計(jì)時(shí)效果(移動(dòng)端和PC端)

    這篇文章主要介紹了通過Html+Css+js如何實(shí)現(xiàn)春節(jié)倒計(jì)時(shí)效果,本文同時(shí)介紹了移動(dòng)端和PC端兩種效果,感興趣的同學(xué)可以跟隨小編一起動(dòng)手試試
    2022-01-01
  • JavaScript中的DOM和Timer的基本操作

    JavaScript中的DOM和Timer的基本操作

    掌握J(rèn)avaScript中的DOM操作可通過id、class、標(biāo)簽名及CSS選擇器進(jìn)行元素選擇和內(nèi)容修改,Timer定時(shí)器功能包括設(shè)置延時(shí)和間隔執(zhí)行,詳細(xì)介紹了事件處理器和事件監(jiān)聽函數(shù)的使用,以及避免事件覆蓋的建議
    2024-10-10
  • JS面向?qū)ο缶幊袒A(chǔ)篇(二) 封裝操作實(shí)例詳解

    JS面向?qū)ο缶幊袒A(chǔ)篇(二) 封裝操作實(shí)例詳解

    這篇文章主要介紹了JS面向?qū)ο缶幊谭庋b操作,結(jié)合實(shí)例形式詳細(xì)分析了JS面向?qū)ο蠓庋b操作的相關(guān)概念、原理、使用方法與操作注意事項(xiàng),需要的朋友可以參考下
    2020-03-03
  • 使用ECharts進(jìn)行數(shù)據(jù)可視化的代碼詳解

    使用ECharts進(jìn)行數(shù)據(jù)可視化的代碼詳解

    ECharts 是一個(gè)由百度開源的強(qiáng)大、靈活的 JavaScript 圖表庫,用于在 Web 頁面上創(chuàng)建各種類型的數(shù)據(jù)可視化圖表,它具有豐富的圖表類型、強(qiáng)大的配置選項(xiàng)和良好的跨平臺(tái)兼容性,本文介紹了如何使用ECharts進(jìn)行數(shù)據(jù)可視化,需要的朋友可以參考下
    2024-08-08
  • javascript奇異的arguments分析

    javascript奇異的arguments分析

    在 Javascript 的函數(shù)中有個(gè)名為 arguments 的類數(shù)組對(duì)象。它看起來是那么的詭異而且名不經(jīng)傳,但眾多的 Javascript 庫都使用著它強(qiáng)大的功能。所以,它的特性需要每個(gè) Javascript 程序員去熟悉它。
    2010-10-10
  • JavaScript學(xué)習(xí)筆記之?dāng)?shù)組求和方法

    JavaScript學(xué)習(xí)筆記之?dāng)?shù)組求和方法

    這篇文章主要介紹了JavaScript學(xué)習(xí)筆記之?dāng)?shù)組求和方法的相關(guān)資料,需要的朋友可以參考下
    2016-03-03
  • Easyui form combobox省市區(qū)三級(jí)聯(lián)動(dòng)

    Easyui form combobox省市區(qū)三級(jí)聯(lián)動(dòng)

    這篇文章主要介紹了Easyui form combobox省市區(qū)三級(jí)聯(lián)動(dòng) 的相關(guān)資料,需要的朋友可以參考下
    2016-01-01
  • Javascript數(shù)組的?forEach?方法詳細(xì)介紹

    Javascript數(shù)組的?forEach?方法詳細(xì)介紹

    這篇文章主要介紹了Javascript數(shù)組的forEach方法詳細(xì)介紹,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-09-09
  • JS動(dòng)態(tài)給對(duì)象添加屬性和值的實(shí)現(xiàn)方法

    JS動(dòng)態(tài)給對(duì)象添加屬性和值的實(shí)現(xiàn)方法

    下面小編就為大家?guī)硪黄狫S動(dòng)態(tài)給對(duì)象添加屬性和值的實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-10-10
  • JavaScript節(jié)點(diǎn)及列表操作實(shí)例小結(jié)

    JavaScript節(jié)點(diǎn)及列表操作實(shí)例小結(jié)

    這篇文章主要介紹了JavaScript節(jié)點(diǎn)及列表操作的方法,以實(shí)例的形式較為詳細(xì)的總結(jié)了javascript針對(duì)節(jié)點(diǎn)操作的相關(guān)技巧,并給出了一個(gè)完整的節(jié)點(diǎn)操作方法實(shí)例總結(jié),需要的朋友可以參考下
    2015-08-08

最新評(píng)論