欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談nodejs中的類定義和繼承的套路

 更新時間:2017年07月26日 09:56:14   作者:隨風而行之青衫磊落險峰行  
本篇文章主要介紹了淺談nodejs中的類定義和繼承的套路,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

javascript是一門極其靈活的語言。

靈活到你無法忍受!

我個人喜歡強類型的語言,例如c/c++,c#等。

但是js代表著未來,所以需要學習。

js中類定義以及繼承有n多種方式,現(xiàn)在來學習一下nodejs類定義以及繼承的固定套路。

套路1. 在構(gòu)造函數(shù)(constructor)中總是使用instanceof操作符:

function Base() {
  if (!(this instanceof Base)) {
    return new Base();
  }
}

上述代碼的含義就是: 如果Base這個函數(shù)調(diào)用時沒有使用new操作符,則會自動調(diào)用new操作符,返回Base的實例

套路2. 所有成員變量定義在構(gòu)造函數(shù)(constructor)中

function Base() {
  if (!(this instanceof Base)) {
    return new Base();
  }

  //開始成員變量定義
  this.className = "Base";
}

套路3. 所有的成員方法以函數(shù)表達式方式定義在原型(prototype)中【為什么要這樣,其原因在套路4中的inherits源碼注釋中】

Base.prototype.printClassName = function(){
   console.log(this.className);
}

調(diào)用如下:

var base = Base(); //不使用new操作符,直接進行函數(shù)調(diào)用,自動調(diào)用new操作符
console.log(base.className);
base.printClassName();

套路4. 使用util.inherits(子類,父類)進行原型(prototype)繼承

先來看一下inherits的源碼:

var inherits = function(ctor, superCtor) {
  //嚴格相等測試:undefined/null
  //子類構(gòu)造函數(shù)必須存在
  if (ctor === undefined || ctor === null)
    throw new TypeError('The constructor to "inherits" must not be ' +
      'null or undefined');
  //嚴格相等測試:undefined/null
  //父類構(gòu)造函數(shù)必須存在
  if (superCtor === undefined || superCtor === null)
    throw new TypeError('The super constructor to "inherits" must not ' +
      'be null or undefined');

  //要點: 如果要繼承的話,父類必須要有prototype對象
  //這也是為什么將所有成員方法都定義在prototype對象中!??!
  if (superCtor.prototype === undefined)
    throw new TypeError('The super constructor to "inherits" must ' +
      'have a prototype');

  //讓子類構(gòu)造函數(shù)對象增加一個super_指針,指向父類,這樣就形成繼承鏈
  ctor.super_ = superCtor;

  //調(diào)用Object.setPrototypeOf(子類的prototype,父類的prototype)
  Object.setPrototypeOf(ctor.prototype, superCtor.prototype);
};

Object.setPrototypeOf : 該鏈接可以了解一下setPrototypeOf方法,非常簡單,其Polyfill如下:

// 僅適用于Chrome和FireFox,在IE中不工作:
Object.setPrototypeOf = Object.setPrototypeOf || function (obj, proto) {
 obj.__proto__ = proto;
 return obj; 
}

我們來測試一下繼承。

先定義子類

function Child() {
  //老樣子,套路1
  if (!(this instanceof Child)) {
    return new Child();
  }
}

然后根據(jù)套路4, 調(diào)用inherits函數(shù)進行原型繼承

//注意,inherits調(diào)用不在構(gòu)造函數(shù),也不在原型對象,而是全局調(diào)用
inherits(Child, Base);

最后我們調(diào)用一下child的printClassName方法,該方法在基類原型對象中實現(xiàn)。

子類調(diào)用基類函數(shù)-undefined.png

出現(xiàn)錯誤,child.printClassName()后輸出undefined!

為什么呢?

套路5. 子類的構(gòu)造函數(shù)中使用 父類.call(this),實現(xiàn)父類構(gòu)造函數(shù)中的成員變量繼承

function Child() {
  //老樣子,套路1
  if (!(this instanceof Child)) {
    return new Child();
  }

  //增加這句話,在調(diào)用printClassName就能正常的輸出Base字符串
  Base.call(this);

  //如果要更新基類的成員變量,請在Base.call(this)之后!
  this._className = "Child"; //調(diào)用printClassName就能正常的輸出Child字符串
}

Function.prototype.call()

由此可見,nodejs中的繼承需要:

在構(gòu)造函數(shù)中調(diào)用 父類.call(this),實現(xiàn)父類成員變量的繼承

全局調(diào)用inherits(子類,父類) 進行父類成員函數(shù)的繼承

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • node.js中的fs.lstatSync方法使用說明

    node.js中的fs.lstatSync方法使用說明

    這篇文章主要介紹了node.js中的fs.lstatSync方法使用說明,本文介紹了fs.lstatSync的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • 使用基于Node.js的構(gòu)建工具Grunt來發(fā)布ASP.NET MVC項目

    使用基于Node.js的構(gòu)建工具Grunt來發(fā)布ASP.NET MVC項目

    這篇文章主要介紹了使用基于Node.js的構(gòu)建工具Grunt來發(fā)布ASP.NET MVC項目的教程,自動化構(gòu)建工具Grunt具有編譯壓縮單元測試等功能,十分強大,需要的朋友可以參考下
    2016-02-02
  • Node爬蟲工具Puppeteer入門教程實踐

    Node爬蟲工具Puppeteer入門教程實踐

    Puppeteer是一個Node庫,本文主要介紹了Node爬蟲工具Puppeteer入門教程實踐,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • node.js中的fs.fsyncSync方法使用說明

    node.js中的fs.fsyncSync方法使用說明

    這篇文章主要介紹了node.js中的fs.fsyncSync方法使用說明,本文介紹了fs.fsyncSync的方法說明、語法、接收參數(shù)、使用實例和實現(xiàn)源碼,需要的朋友可以參考下
    2014-12-12
  • NodeJS學習筆記之FS文件模塊

    NodeJS學習筆記之FS文件模塊

    在看nodejs介紹的過程中,nodejs對自己的異步I/O是重點突出的說明的。在fs模塊中,nodejs提供了異步和同步兩種讀寫方式
    2015-01-01
  • express框架中使用jwt實現(xiàn)驗證的方法

    express框架中使用jwt實現(xiàn)驗證的方法

    這篇文章主要給大家介紹了關(guān)于express框架中使用jwt實現(xiàn)驗證的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用express具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08
  • Node.js的Koa實現(xiàn)JWT用戶認證方法

    Node.js的Koa實現(xiàn)JWT用戶認證方法

    本篇文章主要介紹了Node.js的Koa實現(xiàn)JWT用戶認證方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • Nodejs--post的公式詳解

    Nodejs--post的公式詳解

    本篇文章主要介紹了Nodejs--post公式的相關(guān)知識,具有很好的參考價值。下面跟著小編一起來看下吧
    2017-04-04
  • 初探nodeJS

    初探nodeJS

    本文主要介紹了nodeJS的基礎(chǔ)知識。具有很好的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • Node.js中的模塊路徑解析規(guī)則和子模塊包

    Node.js中的模塊路徑解析規(guī)則和子模塊包

    NodeJS特性如事件驅(qū)動、異步編程、無阻塞IO,這些特性為它帶來了高效的性能和更少的代碼,require函數(shù)支持斜杠(/)或盤符(C:)開頭的絕對路徑,也支持./開頭的相對路徑,為了便于管理和使用,我們可以把由多個子模塊組成的大模塊稱做包,并把所有子模塊放在同一個目錄里
    2023-11-11

最新評論