`
sjpsega
  • 浏览: 300700 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

javascript中的继承

    博客分类:
  • web
 
阅读更多

之前看了《JavaScript设计模式》中面向对象,对象继承的内容,书很经典,但实现方式我是不太理解。
今天看了《编写高质量代码-Web前端开发修炼之道》这本书中面向对象的相关内容,对js的继承,有点廓然开朗的感觉,循循善诱。这本书全篇都非常不错,值得一看。我想很大原因是国人原创,根据自身实践写出来的原因吧,跟外文翻译的还有有所不同的。
记录下js的继承方式,当然js的继承分类式继承和原型继承,我比较习惯类式继承。
Book基类:

          var Book = function(name){
              if(this.check(name)){
                  console.log("error");
                  throw new Error("name null");
              }
              this.name = name;
          }
          Book.prototype = {
              check:function(name){
                  if(!name){
                      return true;
                  }
              },
              getName:function(){
                  return this.name;
              }
          }

  

继承方法:

              function extend(subClz,superClz){
              var F = function(){}
              F.prototype = superClz.prototype;
              subClz.prototype = new F();
              subClz.prototype.constructor = subClz;
              subClz.superClass = superClz.prototype;
              if(superClz.prototype.constructor == Object.prototype.constructor){
                  superClz.prototype.constructor = superClz;
              }
          }

  
使用空函数F作为桥接,可以避免直接实例化父类时调用父类的构造函数带来额外开销,而且当父类的构造函数有参数时,想直接通过subClass.prototype = new superClass();实现父类构造函数的调用和原型链的继承是不行的。

              subClz.superClass = superClz.prototype;
              if(superClz.prototype.constructor == Object.prototype.constructor){
                  superClz.prototype.constructor = superClz;
              }

 
添加这三句可以避免子类继承父类写Book.call(this,name);而是简单地写ArtBook.superClass.Constructor.call(this,name)便能实现。
并且在子类重写父类方法的时候,可以调用到父类的方法:

 

ArtBook.prototype.getName = functiion(){
    return ArtBook.superClass.getName.call(this) + "!!!";
}
 

 


ArtBook子类:

 

          var ArtBook = function(name,price){
              ArtBook.superClass.Constructor.call(this,name);
              this.price = price;
          }
          extend(ArtBook,Book);
          ArtBook.prototype.getPrice = function(){
                  return this.price;
          }
          ArtBook.prototype.getName = function(){
                return ArtBook.superClass.getName.call(this)+"!!!";
           }
 


参考资料:
javascript设计模式:继承

分享到:
评论

相关推荐

    JavaScript中继承原理与用法实例入门

    JavaScript中的继承是面向对象编程的重要概念,它允许一个对象(子对象)继承另一个对象(父对象)的属性和方法。在JavaScript中,由于其动态类型和基于原型的特性,实现继承的方式比传统的面向对象语言更为灵活,但...

    JavaScript中继承用法实例分析

    在给定的文件内容中,我们看到一个具体的JavaScript继承的例子,主要分为以下几个步骤: 1. 定义父类`Person`,这个类有一个原型方法`walk`和`sayHello`,它们分别用于定义行走和打招呼的行为。 ```javascript ...

    JavaScript中继承的一些示例方法与属性参考

    JavaScript继承是面向对象编程(OOP)中的一个核心概念,它允许一个对象(称为子类或派生类)继承另一个对象(称为父类或基类)的属性和方法。JavaScript是一种基于原型的编程语言,它实现继承的方式与其他基于类的...

    base-object:JavaScript 中继承的实现

    JavaScript 中继承的实现 怎么建? git clone 这个仓库 切换到新目录 npm install npm run build 用法 var Person = BaseObject . extend ( { init : function ( name , age ) { this . name = name ; this . ...

    JavaScript继承

    JavaScript中的继承是一个核心概念,它在面向对象编程中扮演着至关重要的角色。与其他面向对象语言相比,JavaScript的继承机制更为复杂。在Java或C++等语言中,继承通常只需要一个关键字,如`extends`,但在...

    JavaScript中实现继承的八种方式

    详细介绍了JavaScript中继承的实现方式以及其优缺点分析。

    JavaScript实现继承的几种方式

    寄生组合继承解决了组合继承中父类构造函数会被调用两次的问题,通过创建父类的一个不被使用的实例,然后将子类的原型指向这个实例的原型。 ```javascript function inheritPrototype(subType, superType) { let ...

    JavaScript学习之三 — JavaScript实现继承的7种方式

    在JavaScript中,选择合适的继承方式取决于具体需求。理解并熟练掌握这些继承方式,能让你在编写代码时更加游刃有余。文章中的`inheritance.html`和`inheritance.js`文件可能包含示例代码,帮助你直观地了解每种继承...

    javascript控件开发之继承关系

    在这个主题中,“javascript控件开发之继承关系”主要探讨的是如何利用JavaScript的面向对象特性来构建和组织控件的层次结构,以及如何通过继承来实现代码的复用和模块化。 在JavaScript中,继承是基于原型...

    JavaScript中的类继承

    JavaScript中的类继承是一种模拟传统面向对象编程中类概念的方式,因为JavaScript本身是一种基于原型的面向对象语言。在JavaScript中,对象可以直接从其他对象继承属性和方法,而不是通过类的实例化。这种继承机制...

    实现JavaScript中继承的三种方式

    在原型链继承中,子类型的原型对象指向父类型的实例,从而使得子类型的实例可以继承父类型原型上的属性和方法。原型链继承允许子类型访问父类型的实例属性和方法,这在JavaScript中是通过设置子类型的prototype指向...

    浅析Javascript原型继承

    JavaScript中的原型继承是一种基于原型(Prototype)的继承机制,它不同于传统的类继承,而是通过对象之间的关联来实现对象间的共享属性和方法。在JavaScript中,每个函数都有一个`prototype`属性,这个属性是一个...

    学习javascript面向对象 javascript实现继承的方式

    本文将详细介绍六种实现JavaScript继承的方法。 1. 原型链继承 原型链继承是通过改变子类型的原型对象来实现继承的。子类型构造函数的原型被替换为超类型构造函数的一个实例,这样子类型就可以继承超类型的所有属性...

    javascript继承之为什么要继承.docx

    JavaScript 中的继承机制是指子类继承父类的属性和方法,使得子类可以拥有父类的所有特征。继承是面向对象编程的基本机制之一,它可以实现代码复用、提高编程效率和增强代码的可维护性。 在 JavaScript 中,继承是...

    理解Javascript原型继承原理

    在JavaScript中,原型继承是一种非常核心且独特的机制,它使得对象能够继承其他对象的属性和方法。本文旨在深入探讨这一机制,并通过具体的示例代码帮助读者更好地理解其中的概念。 #### 二、基本概念 在JavaScript...

    JavaScript继承机制研究.pdf

    在本文中,我们将深入探讨JavaScript继承机制的实现方式,并对基于原型的继承、构造函数方式继承、组合继承、寄生式继承等继承机制进行了总结归纳和分析。 基于原型的继承 JavaScript是一门基于原型的语言,它不像...

Global site tag (gtag.js) - Google Analytics