javascript 繼承實現

來源:互聯網
上載者:User

標籤:

JavaScript進階程式設計讀書筆記

這本書繼承的實現列舉了好幾種,裡面有兩種是比較靠譜的。

1 組合繼承

//父建構函式function Super(name) {    this.name = name;    this.colors = [‘black‘, ‘red‘];}
Super.prototype.getName = function() { return this.name;}

//子建構函式function Sub(name, age) { Super.call(this, name); this.age = age;}
//把Sub的原型修改為Super的執行個體,就能繼承Super.prototype中的屬性和方法了,
//這樣存在的問題是:把name和colors屬性也添加到Sub.prototype中了,這部分對執行個體是不可見的,
//因為調用new Sub()產生執行個體時,會把name和colors添加為執行個體屬性Sub.prototype = new Super();Sub.prototype.getAge = function(){ return this.age;}
//前面修改Sub.prototype時,導致Sub.prototype.constructor指向了Super,所以要修改回來
Sub.prototype.constructor = Sub; 
var ins1 = new Sub(‘mengxb‘, 28);

2 寄生組合式繼承

function Object(o) {    function F() {};    F.prototype = o;    return new F();}function inheritPrototype(sub, super) {    var prototype = Object(super.prototype);    sub.prototype = prototype;    sub.prototype.construtor = sub;}function Super(name) {    this.name = name;    this.colors = [‘black‘, ‘red‘];}Super.prototype.getName = function() {    return this.name;}function Sub(name, age) {    Super.call(this, name);    this.age = age;}inheritPrototype(Sub, Super);Sub.prototype.getAge = function(){    return this.age;}

 

javascript 繼承實現

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.