亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > JS > 正文

JavaScript 繼承 封裝 多態實現及原理詳解

2024-05-06 16:53:47
字體:
來源:轉載
供稿:網友

面向對象的三大特性

封裝

所謂封裝,也就是把客觀事物封裝成抽象的類,并且類可以把自己的數據和方法只讓可信的類或者對象操作,對不可信的進行信息隱藏。封裝是面向對象的特征之一,是對象和類概念的主要特性。 簡單的說,一個類就是一個封裝了數據以及操作這些數據的代碼的邏輯實體。在一個對象內部,某些代碼或某些數據可以是私有的,不能被外界訪問。通過這種方式,對象對內部數據提供了不同級別的保護,以防止程序中無關的部分意外的改變或錯誤的使用了對象的私有部分。

我們在vue項目中使用混入將公有代碼提出來,混入到每個需要的組件中,讓我們的代碼更簡潔

我們也可以將一些公用的方法,工具進行封裝,達到代碼復用,讓我們的代碼更簡潔

繼承

所謂繼承是指可以讓某個類型的對象獲得另一個類型的對象的屬性的方法。它支持按級分類的概念。繼承是指這樣一種能力:它可以使用現有類的所有功能,并在無需重新編寫原來的類的情況下對這些功能進行擴展。 通過繼承創建的新類稱為“子類”或“派生類”,被繼承的類稱為“基類”、“父類”或“超類”。繼承的過程,就是從一般到特殊的過程。要實現繼承,可以通過“繼承”(Inheritance)和“組合”(Composition)來實現。繼承概念的實現方式有二類:實現繼承與接口繼承。實現繼承是指直接使用基類的屬性和方法而無需額外編碼的能力;接口繼承是指僅使用屬性和方法的名稱、但是子類必須提供實現的能力;

實現繼承的幾種方式

call繼承

function a (){    this.c=111  }  function b(){    a.call(this)  }  let d = new b()  console.log(d.c) // 111

上面代碼相當于函數b繼承了函數a的私有屬性,通過改變父類的this實現繼承

原型繼承

 function a (){    this.c=111  }  a.prototype.getName=function(){    return '你好'  }  function b(){    // a.call(this)  }  b.prototype=new a()  b.constructor=b  let d = new b()  console.log(d.c) // 111  console.log(d.getName()) // 你好

原型繼承通過將父類的實例賦值給子類的原型,這種方法子類可以繼承父類的私有方法也可以繼承父類的私有方法

寄生組合繼承

 function a (){    this.c=111  }  a.prototype.getName=function(){    return '你好'  }  function b(){    a.call(this)  }  b.prototype=Object.create(a.prototype)  let d = new b()  console.log(d.c) // 111  console.log(d.getName()) // 你好

寄生組合繼承就是使用call繼承改變this,實現私有繼承私有,使用object.create實現公有繼承公有

es6 extends 繼承

class parent{    constructor(){      this.a=1    }    name(){      return 2    }  }  class child extends parent{      }  let A = new child()  console.log(A.a) // 1  console.log(A.name()) // 2

這里通過關鍵字extends實現子類繼承父類的私有和公有,這里需要注意如果子類里面寫了constructor,就必須寫super否則會報錯

class parent{    constructor(){      this.a=1    }    name(){      return 2    }  }  class child extends parent{    constructor(){    // 這里不寫super會報錯,報錯信息如下    }  }  // ncaught ReferenceError: Must call super constructor in derived class before accessing 'this' or returning from derived constructor at new child

多態

所謂多態就是指一個類實例的相同方法在不同情形有不同表現形式。多態機制使具有不同內部結構的對象可以共享相同的外部接口。這意味著,雖然針對不同對象的具體操作不同,但通過一個公共的類,它們(那些操作)可以通過相同的方式予以調用。

重載

函數重載是指在同一作用域內,可以有一組具有相同函數名,不同參數列表的函數,這組函數被稱為重載函數。重載函數通常用來命名一組功能相似的函數,這樣做減少了函數名的數量,避免了名字空間的污染,對于程序的可讀性有很大的好處。

  • js通過函數名找到對應的函數對象
  • 然后根據函數按照定義時的參數,和表達式參數列表按順序匹配,多余的參數舍去,不夠的參數按undefined處理
  • 然后執行函數代碼。
 // 可以跟據arguments個數實現重載  function add() {    var sum = 0 ;    for ( var i = 0 ; i < arguments.length; i ++ ) {      sum += arguments[i];    }    return sum;  }  console.log(add()) // 0  console.log(add(1,2)) // 3  console.log(add(1,2,3)) // 6

重寫

“實例中的指針僅指向原型,而不是指向構造函數”。

“重寫原型對象切斷了現有原型與任何之前已經存在的對象實例之間的關系;它們引用的仍然是最初的原型”。

var parent = function(name,age){  this.name = name;  this.age = age;} parent.prototype.showProper = function(){  console.log(this.name+":"+this.age);} var child = function(name,age){  parent.call(this,name,age);} // inheritancechild.prototype = Object.create(parent.prototype);// child.prototype = new parent();child.prototype.constructor = child; // rewrite functionchild.prototype.showProper = function(){  console.log('I am '+this.name+":"+this.age);}var obj = new child('wozien','22');obj.showProper();

上面這段代碼通過使用寄生組合繼承,實現子類私有繼承父類私有,子類公有繼承父類公有,達到重寫父類的showProper

面向對象的5大原則

  • 單一職責原則
  • 開放封閉原則
  • 替換原則
  • 依賴原則
  • 接口分離原則

單一職責原則

單一職責原則就是我們說的一個方法只做一件事,就比如現在的項目結構,就遵循了單一職責原則

開放封閉原則

開放封閉原則就是對修改關閉,對擴展開放

class a {   add(){     return 11   } } class b extends a{    } let c = new b() console.log(c.add()) // 111

我們可以使用extends繼承父類,可以再b里面修改add函數,實現對修改關閉,對擴展開放

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩av在线免费看| 成人精品视频99在线观看免费| 国产91色在线|免| 国产综合久久久久| 日韩中文在线视频| 91久久精品久久国产性色也91| 欧美成人精品一区二区三区| 欧美电影免费观看高清完整| 国产精品久久综合av爱欲tv| 亚洲精品日韩久久久| 日韩欧美国产高清91| 5566成人精品视频免费| 国产精品69久久久久| 91精品综合视频| 中文字幕日韩在线观看| 97久久久免费福利网址| 国产精品入口夜色视频大尺度| 亚洲一级黄色av| 永久免费毛片在线播放不卡| 日韩电影大片中文字幕| 精品色蜜蜜精品视频在线观看| 日本老师69xxx| 欧美乱大交xxxxx| 日韩精品亚洲视频| 久久久精品免费视频| 欧美国产亚洲视频| 97精品国产97久久久久久免费| 久久这里有精品视频| 日韩精品视频免费| 成人激情视频免费在线| 91情侣偷在线精品国产| 国产999在线观看| 最近2019中文免费高清视频观看www99| xxxxx成人.com| 亚洲综合色av| 亚洲伦理中文字幕| 欧美日韩国产一区二区| 欧美一区深夜视频| 欧美在线视频在线播放完整版免费观看| 欧美综合国产精品久久丁香| 亚洲精品国产精品国产自| 国产日韩精品在线播放| 成人网在线视频| 欧美二区在线播放| 亚洲国产欧美在线成人app| 亚洲欧洲中文天堂| 97成人超碰免| 91在线无精精品一区二区| 九九视频直播综合网| www.色综合| 精品久久中文字幕久久av| 欧美亚洲另类激情另类| 久久国产精品久久精品| 欧美日韩在线一区| 日韩av在线免费观看| 中文字幕最新精品| 欧美电影电视剧在线观看| 久久精品成人欧美大片| 日韩欧美国产激情| 亚洲网站在线看| 国产精品视频男人的天堂| 精品少妇v888av| 欧美老女人xx| 日韩精品福利网站| 久久精品电影网| 日韩在线观看你懂的| 日韩视频在线免费| 精品久久久久久久久久久久久| 成人黄色av播放免费| 亚洲奶大毛多的老太婆| 欧美激情国内偷拍| 国产欧美日韩中文| 日韩在线视频线视频免费网站| 97精品欧美一区二区三区| 成人精品久久av网站| 国产精品免费一区豆花| 精品高清美女精品国产区| 青青在线视频一区二区三区| 日韩中文在线不卡| 97高清免费视频| 国产视频精品在线| 久久人人爽人人| 国产欧美一区二区白浆黑人| 91免费综合在线| 久久综合色88| 96精品久久久久中文字幕| 精品一区二区三区三区| 精品偷拍各种wc美女嘘嘘| 中文字幕一区二区精品| 7777免费精品视频| 一本色道久久综合狠狠躁篇怎么玩| 久久九九有精品国产23| 国产狼人综合免费视频| 亚洲综合视频1区| 国产区亚洲区欧美区| 亚洲第一在线视频| 国产不卡精品视男人的天堂| 欧美中文字幕第一页| 国产视频在线观看一区二区| 欧美寡妇偷汉性猛交| 亚洲午夜精品视频| 亚洲高清久久久久久| 国产精品羞羞答答| 日韩女优在线播放| 国产免费亚洲高清| 亚洲国内精品视频| 亚洲精品美女网站| 国产精品日韩久久久久| 日韩成人av在线| 欧美激情在线有限公司| 成人精品一区二区三区电影免费| 日韩高清av一区二区三区| 另类图片亚洲另类| 91超碰caoporn97人人| 久久精品久久精品亚洲人| 国产精品旅馆在线| 91国产视频在线播放| 国产裸体写真av一区二区| 国产91成人在在线播放| 国产精品久久9| 久久这里有精品视频| 亚洲女人被黑人巨大进入| 在线精品国产欧美| 亚洲精品成人免费| 精品日本美女福利在线观看| 久久亚洲私人国产精品va| 亚洲白虎美女被爆操| 亚洲丝袜av一区| 欧美激情va永久在线播放| 国产精品福利久久久| 久久天天躁夜夜躁狠狠躁2022| 久久久久久网站| 亚洲第一视频网| 96pao国产成视频永久免费| 在线丨暗呦小u女国产精品| 国产日韩欧美另类| 九九热精品视频在线播放| 日韩三级影视基地| 亚洲香蕉伊综合在人在线视看| 亚洲欧洲日韩国产| 91爱视频在线| 国产精品电影久久久久电影网| 日韩欧美亚洲成人| 国产精品永久免费视频| 欧美国产日本在线| 国产精品美乳一区二区免费| 久久亚洲私人国产精品va| 亚洲色图狂野欧美| 中文字幕亚洲情99在线| 91人人爽人人爽人人精88v| 亚洲精品乱码久久久久久金桔影视| 国产成人亚洲综合91| 中文字幕精品久久| 国产亚洲免费的视频看| 91黑丝在线观看| 中文字幕免费精品一区| 欧美激情网站在线观看| 日韩精品视频在线观看网址| 亚洲一区二区三区777| 日本精品久久久久影院| 欧美在线国产精品| 日韩中文在线观看| 久久99视频精品| 久久成人国产精品|