摘要:重新掛載原型將之前的原型合并進去調用父類方法調用父類構造函數
var es = {}; es.extend = function(dist, src) { for (var k in src) { if (src.hasOwnProperty(k)) { dist[k] = src[k]; } } }; es.inherit = function(Klass, Base) { function f() {} f.prototype = Base.prototype; Klass.prototype = new f; Klass.prototype.constructor = Klass; Klass.Base = Base; }; es.create = function(oo) { var Klass = oo.init; function realBase(fn) { var count = 0; function realBase() { var Base = Klass.Base, i = 0; while(count !== i) { Base = Base.Base; i++; } count++; fn.call(this, Base, arguments); count--; } return realBase; } oo.Base = realBase(function(Base, argv) { Base.apply(this, argv); }); oo.oo = realBase(function(Base, argv) { Base.prototype[argv[0]].apply(this, [].slice.call(argv, 1)); }); Klass.prototype = oo; Klass.extend = function(Base) { var Klass = this; var old = Klass.prototype; es.inherit(Klass, Base);//Klass重新掛載原型 es.extend(Klass.prototype, old); //將之前的原型合并進去 return Klass; }; return Klass; }; /////////////////////test//////////////// var People = es.create({ init: function(name) { this.name = name; }, intro: function() { console.log("I am " + this.name); } }); var Student = es.create({ intro: function() { this.oo("intro");//調用父類方法 console.log("I am learning " + this.lesson); }, init: function(name, lesson) { this.Base(name); this.lesson = lesson; } }).extend(People); var Son = es.create({ init: function(name, lesson, age) { this.Base(name, lesson);//調用父類構造函數 this.age = age; }, intro: function() { this.oo("intro"); console.log("I am " + this.age + " years old"); } }).extend(Student); var p = new People("eric"); p.intro(); var s = new Student("eric", "js") s.intro(); var son = new Son("eric", "js", 34); son.intro();
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/78772.html
摘要:這正是我們想要的太棒了毫不意外的,這種繼承的方式被稱為構造函數繼承,在中是一種關鍵的實現的繼承方法,相信你已經很好的掌握了。 你應該知道,JavaScript是一門基于原型鏈的語言,而我們今天的主題 -- 繼承就和原型鏈這一概念息息相關。甚至可以說,所謂的原型鏈就是一條繼承鏈。有些困惑了嗎?接著看下去吧。 一、構造函數,原型屬性與實例對象 要搞清楚如何在JavaScript中實現繼承,...
摘要:中的繼承并不是明確規定的,而是通過模仿實現的。繼承中的繼承又稱模擬類繼承。將函數抽離到全局對象中,函數內部直接通過作用域鏈查找函數。這種范式編程是基于作用域鏈,與前面講的繼承是基于原型鏈的本質區別是屬性查找方式的不同。 這一節梳理對象的繼承。 我們主要使用繼承來實現代碼的抽象和代碼的復用,在應用層實現功能的封裝。 javascript 的對象繼承方式真的是百花齊放,屬性繼承、原型繼承、...
摘要:繼承前言作為一門輕量級的腳本語言在和的橫空出世之后將其推向的新的高度雖然中出現的新的生成對象的類語法格式但依然為的語法糖而我們依然有必要從的原生實現入手來了解它的繼承實現方式給出了更加簡潔的固定的類聲明方式有興趣的可以查看阮一峰的入門下面給 javascript繼承 前言 javascript作為一門輕量級的腳本語言在ES6和node.js的橫空出世之后將其推向的新的高度,雖然 ES6...
摘要:我們有了構造函數之后,第二步開始使用它構造一個函數。來個例子這種方式很簡單也很直接,你在構造函數的原型上定義方法,那么用該構造函數實例化出來的對象都可以通過原型繼承鏈訪問到定義在構造函數原型上的方法。 來源: 個人博客 白話解釋 Javascript 原型繼承(prototype inheritance) 什么是繼承? 學過面向對象的同學們是否還記得,老師整天掛在嘴邊的面向對象三大特...
摘要:和構造函數前面提到,是個內置隱藏屬性,雖然在可以通過訪問,但是其設計本意是不可被讀取和修改的,那么我們如何利用原型鏈來建立繼承關系提供了關鍵字。到這兒,思路就清晰了,怎么讓對象和對象的相連實現繼承只需把的構造函數的連接到就行了。 什么是繼承? 大多數人使用繼承不外乎是為了獲得這兩點好處,代碼的抽象和代碼的復用。代碼的抽象就不用說了,交通工具和汽車這類的例子數不勝數,在傳統的OO語言中(...
閱讀 3197·2021-11-08 13:18
閱讀 1353·2021-10-09 09:57
閱讀 1182·2021-09-22 15:33
閱讀 3960·2021-08-17 10:12
閱讀 5053·2021-08-16 11:02
閱讀 2676·2019-08-30 10:56
閱讀 962·2019-08-29 18:31
閱讀 3251·2019-08-29 16:30