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

首頁 > 語言 > JavaScript > 正文

由淺入深講解Javascript繼承機制與simple-inheritance源碼分析

2024-05-06 16:26:16
字體:
來源:轉載
供稿:網友
Javascript語言對繼承實現的并不好,需要工程師自己去實現一套完整的繼承機制。下面我們由淺入深的系統掌握使用javascript繼承的技巧,對javascript繼承相關知識感興趣的朋友一起看看吧
 

老生常談的問題,大部分人也不一定可以系統的理解。Javascript語言對繼承實現的并不好,需要工程師自己去實現一套完整的繼承機制。下面我們由淺入深的系統掌握使用javascript繼承的技巧。

1. 直接使用原型鏈

這是最簡粗暴的一種方式,基本沒法用于具體的項目中。一個簡單的demo如下:

function SuperType(){  this.property = true;}SuperType.prototype.getSuperValue = function(){  return this.property;}function SubType(){  this.subproperty = false;}//繼承SubType.prototype = new SuperType();SubType.prototype.getSubValue = function(){  return this.subproperty;}var instance = new SubType();

這種方式的問題是原型中的屬性會被所用實例共享,通過一個實例改變一個繼承過來的屬性時,會影響到其他實例。,這顯然不是一種常規意義上的繼承。

2.使用構造函數

構造函數本質上也只是一個函數而已,可以在任何作用域中調用,在子構造函數中調用父構造函數,就可以實現簡單的繼承。

function SuperType(){  this.colors = {"red","blue","green"}}function SubType(){  SuperType.call(this);  }var instance = new SubType();

這種實現避免了多個實例共享屬性的問題,但是又出現了新的問題,比如沒法共享函數,而且 instance instanceof SuperType 為false。

3. 組合使用原型和構造函數

function SuperType(name){  this.name = name;  this.colors = {"red","blue","green"}}SuperType.prototype.sayName = function(){  //code}function SubType(name,age){  SuperType.call(this,name);   this.age = age;}SubType.prototype = new SuperType();var instance = new SubType();

組合使用原型和構造函數是javascript中最常用的繼承模式。使用這種方式,每個實例都有自己的屬性,同時可以共享原型中的方法。但是這種方式的缺點是:無論什么情況,都會調用兩次超類構造函數。一次是在創建子類原型時,另一次是在子類構造函數內部。這種問題該怎么解決呢?

4. 寄生組合式繼承

SubType的原型并不一定非要是SuperType的實例,只需是一個構造函數的原型是SuperType的原型的普通對象就可以了。Douglas Crockford的方法如下:

function obejct(o){  function F(){};  F.prototype = o;  return new F();}

其實這也就是ES5中Object.create的實現。那么我們可以修改本文中的第3種方案:

function inheritPrototype(subType,superType){  var prototype = object(superType.prototype);  prototype.constructor = subType;  subType.prototype = prototype;}function SuperType(name){  this.name = name;  this.colors = {"red","blue","green"}}SuperType.prototype.sayName = function(){  //code}function SubType(name,age){  SuperType.call(this,name);   this.age = age;}inheritPrototype(SubType,SuperType);var instance = new SubTYpe();

其實寄生組合式繼承已經是一種非常好的繼承實現機制了,足以應付日常使用。如果我們提出更高的要求:比如如何在子類中調用父類的方法呢?

5.simple-inheritance庫的實現

看這么難懂的代碼,起初我是拒絕的,但是深入之后才發現大牛就是大牛,精妙思想無處不在。我對每一行代碼都有詳細的注釋。如果你想了解細節,請務必詳細研究,讀懂每一行。我覺得這個實現最精妙的地方就是按需重寫父類方法,在實例對象中可以通過_super調用父類的同名方法,類似于java的實現。

(function(){  //initializing用于控制類的初始化,非常巧妙,請留意下文中使用技巧  //fnTest返回一個正則比表達式,用于檢測函數中是否含有_super,這樣就可以按需重寫,提高效率。當然瀏覽器如果不支持的話就返回一個通用正則表達式  var initializing = false,fnTest = /xyz/.test(function(){xyz;}) ? //b_super/b/ : /.*/;  //所有類的基類Class,這里的this一般是window對象  this.Class = function(){};  //對基類添加extend方法,用于從基類繼承  Class.extend = function(prop){    //保存當前類的原型    var _super = this.prototype;    //創建當前類的對象,用于賦值給子類的prototype,這里非常巧妙的使用父類實例作為子類的原型,而且避免了父類的初始化(通過閉包作用域的initializing控制)    initializing = true;    var prototype = new this();       initializing = false;    //將參數prop中賦值到prototype中,這里的prop中一般是包括init函數和其他函數的對象    for(var name in prop){      //對應重名函數,需要特殊處理,處理后可以在子函數中使用this._super()調用父類同名構造函數, 這里的fnTest很巧妙:只有子類中含有_super字樣時才處理從寫以提高效率      prototype[name] = typeof prop[name] == "function" && typeof _super[name] == "function" && fnTest.test(prop[name])?       (function(name,fn){        return function(){          //_super在這里是我們的關鍵字,需要暫時存儲一下          var tmp = this._super;           //這里就可以通過this._super調用父類的構造函數了                 this._super = _super[name];          //調用子類函數           fn.apply(this,arguments);          //復原_super,如果tmp為空就不需要復原了          tmp && (this._super = tmp);        }       })(name,prop[name]) : prop[name];    }    //當new一個對象時,實際上是調用該類原型上的init方法,注意通過new調用時傳遞的參數必須和init函數的參數一一對應    function Class(){      if(!initializing && this.init){        this.init.apply(this,arguments);        }    }        //給子類設置原型    Class.prototype = prototype;    //給子類設置構造函數    Class.prototype.constructor = Class;    //設置子類的extend方法,使得子類也可以通過extend方法被繼承    Class.extend = arguments.callee;    return Class;  }})();

通過使用simple-inheritance庫,我們就可以通過很簡單的方式實現繼承了,是不是發現特別像強類型語言的繼承。

var Human = Class.extend({ init: function(age,name){  this.age = age;  this.name = name; }, say: function(){  console.log("I am a human"); }});var Man = Human.extend({  init: function(age,name,height){    this._super(age,name);    this.height = height;  },   say: function(){    this._super();    console.log("I am a man");   }});var man = new Man(21,'bob','191');man.say();

由淺入深講解Javascript繼承機制與simple-inheritance源碼分析,希望本文分享能夠幫助到大家。



注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品成人v| 欧美性猛交xxxx富婆| 国产精品久久久久久久久久ktv| 久久久久久噜噜噜久久久精品| 国产精品一区二区性色av| 亚洲国产精品久久| 亚洲奶大毛多的老太婆| 亚洲美女自拍视频| 92福利视频午夜1000合集在线观看| 91午夜理伦私人影院| 欧美国产极速在线| 欧美一级在线亚洲天堂| 亚洲国产精品小视频| 97超级碰碰人国产在线观看| 成人网中文字幕| 亚洲一区美女视频在线观看免费| 欧美日本亚洲视频| 久久久999国产| 欧美高清videos高潮hd| 国产日韩在线看片| 久久久久久有精品国产| 国产精品久久色| 久久影视三级福利片| 疯狂做受xxxx高潮欧美日本| 亚洲国产精品专区久久| 欧美壮男野外gaytube| 日韩免费高清在线观看| 国产va免费精品高清在线| 欧美在线激情视频| 欧美精品aaa| 久久这里有精品| 国产精品亚洲一区二区三区| 亚洲一区亚洲二区亚洲三区| 精品久久久久久久久中文字幕| 欧美一级电影在线| 日韩av不卡电影| 中文字幕亚洲专区| 欧美国产极速在线| 亚洲欧美日韩爽爽影院| 久热精品视频在线免费观看| 久久亚洲综合国产精品99麻豆精品福利| 亚洲爱爱爱爱爱| 国产欧美一区二区三区四区| 欧美日韩国产在线播放| 91国产美女视频| 色综合色综合网色综合| 欧美日韩国产999| 久久99热精品| 亚洲欧洲中文天堂| 亚洲午夜国产成人av电影男同| 91精品国产高清自在线| 国产精品福利无圣光在线一区| 国模精品一区二区三区色天香| 欧美巨大黑人极品精男| 51视频国产精品一区二区| 日韩在线欧美在线国产在线| 久久久女女女女999久久| 国内精品视频在线| 97精品欧美一区二区三区| 美日韩精品视频免费看| 2019中文字幕免费视频| 日韩一区二区精品视频| 亚洲欧洲自拍偷拍| 最新91在线视频| 日韩最新中文字幕电影免费看| 性视频1819p久久| yellow中文字幕久久| 亚洲丝袜一区在线| 国产在线拍偷自揄拍精品| 欧美日韩性视频| 色综合影院在线| 麻豆乱码国产一区二区三区| 日韩电影中文字幕在线观看| 欧美日韩国产成人在线观看| 日本韩国欧美精品大片卡二| 久久久999精品视频| 久久亚洲一区二区三区四区五区高| 激情懂色av一区av二区av| 美女av一区二区三区| 日韩免费观看高清| 久久免费福利视频| 日本电影亚洲天堂| 中文字幕精品在线视频| 中文字幕精品一区久久久久| 欧美日韩国产影院| 久久网福利资源网站| 欧洲精品在线视频| 日韩av免费在线看| 精品综合久久久久久97| 国产精品自产拍在线观| 亚洲精品欧美日韩专区| 91精品国产乱码久久久久久久久| 亚洲欧美综合图区| 亚洲午夜未满十八勿入免费观看全集| 久久国产精品影片| 26uuu亚洲伊人春色| 日韩色av导航| 欧美亚洲国产成人精品| 亚洲精品一区在线观看香蕉| 91亚洲va在线va天堂va国| 国产精品网站视频| 亚洲天堂第二页| 成人福利视频在线观看| 亚洲小视频在线| 国内精品视频在线| 久久的精品视频| 久久97精品久久久久久久不卡| 亚洲精品国产品国语在线| 成人a级免费视频| 亚洲精品黄网在线观看| 欧美日韩一区免费| 国产精品成人va在线观看| 992tv成人免费影院| 久久久久久亚洲| 疯狂做受xxxx高潮欧美日本| 成人国产精品久久久久久亚洲| 国产精品羞羞答答| 亚洲第一区在线| 欧美高清不卡在线| 97精品国产97久久久久久| 黄色一区二区在线观看| 日韩综合视频在线观看| 亚洲成人国产精品| 欧美午夜女人视频在线| 欧美福利小视频| 亚洲国产天堂久久国产91| 欧美激情视频一区二区三区不卡| 国产日韩欧美在线视频观看| 精品国产福利视频| 久久欧美在线电影| 国产精品亚洲美女av网站| 国产va免费精品高清在线| 日韩欧美在线一区| 久久久人成影片一区二区三区观看| 亚洲韩国青草视频| 777精品视频| 精品亚洲夜色av98在线观看| 国产区精品视频| 日韩专区中文字幕| 日韩久久精品成人| 欧美亚洲在线观看| 国产日韩欧美在线视频观看| 久久亚洲精品一区二区| 精品久久久久久中文字幕大豆网| 欧美综合第一页| 日韩亚洲在线观看| 欧美精品video| 国产精品视频免费观看www| 精品视频久久久久久久| 亚洲一区免费网站| 国产精品久久久久久久午夜| 中文字幕欧美国内| 最近2019中文免费高清视频观看www99| 亚洲精品午夜精品| 久久久久久免费精品| www.欧美精品| 欧美专区国产专区| 国产成人精品综合| 国产精品偷伦免费视频观看的| 影音先锋欧美精品| 国产日韩欧美一二三区| 久久69精品久久久久久国产越南| 久久亚洲精品国产亚洲老地址| 精品久久久香蕉免费精品视频|