要明白javascript中的继承,就要明白javascript中的构造函数及原型的概念(如果不懂原型,请参考我的文档《javascript中的原型》
http://han2000lei.iteye.com/admin/blogs/324686)。
javascript中的构造函数与java的不同:
1.java的构造方法是显式的写在类中,如果不写,则默认有一个无参的构造方法。java在继承时,是类层次上的继承,即一个类继承另一个类。
2.javascript的继承是基于原型的继承。javascript的构造方法就是我们自己定义的一个函数(所有的函数都有一个内置的原型对象,是我们看不见的,但我们可以访问:函数名.prototype ----这就是函数中的原型对象 ),这个函数即是类,又是构造方法。例如:我们有一个代表矩形的构造函数,其定义如下:
function Rectangle(w,h){
this.width = w; //代表矩形的宽
this.height= h; //代表矩形的高
}
Rectangle.prototype.area=function(){//此定义是构造函数原型对象的一个属性,它代表面积
return this.width * this.height;
}
现在,我们要定义一个子类的构造函数(javascript中是通过在构造函数中的定义来实现的继承),来继承这个父类:
1,首先,调用父类的构造函数,以便它能够初始化width和height。我们使用call()方法(如果不知道此方法的作用,请参考我的文档《javascript中的call()与apply()方法》
http://han2000lei.iteye.com/admin/blogs/324680),来援引构造方法使对象初始化。在子类的构造中调用父类的构造,这就是所谓的构造函数链。
function PositionedRectangle(x,y,w,h){
Rectangle.call(this,w,h); //使用函数的call()方法,以便初始化父类构造函数中的属性
this.x = x;
this.y = y;
}
2,当我们定义了这个PositionedRectangle()构造函数来用它创建一个对象时,它会使用默认的原型对象来创建对象,而没有使用父类的原型对象。这样我们得到的子类对象还没有继承父类。我们必须明确地创造我们的原型对象,使子类构造函数中的原型对象成为父类的一个实例。
PositionedRectangle.prototype = new Rectangle();
3.我们建立这个原型对象只是想继承父类中的原型对象,一般情况下并不想继承父类的width和height属性,所以删除它们的原型(注:如果想保留,你也可以不删)。
delete PositionedRectangle.prototype.width;
delete PositionedRectangle.prototype.height;
4,由于父类的构造方法Rectangle()的原型对象的属性constructor,指向父类的构造函数本身。PositionedRectangle构造函数的原型中的constructor现在还是指向的父类的构造,我们必须重新分配此默认构造属性constructor,使用它指向子类的构造函数。
PositionedRectangle.prototype.constructor = PositionedRectangle;
5,好了,现在我们已经配置好了。现在PositionedRectangle已经成为Rectangle的子类了。
可以看出,javascript的继承要比java的继承麻烦的多。不过惯成自然,当熟悉了就不觉的麻烦了,其继承也就这么几步。下面将子类PositionedRectangle的代码综合起来,以方便查看
function PositionedRectangle(x,y,w,h){
Rectangle.call(this,w,h); //使用函数的call()方法,以便初始化父类构造函数中的属性
this.x = x;
this.y = y;
}
PositionedRectangle.prototype = new Rectangle();
delete PositionedRectangle.prototype.width;
delete PositionedRectangle.prototype.height;
PositionedRectangle.prototype.constructor = PositionedRectangle;
分享到:
相关推荐
JavaScript中的继承是面向对象编程的重要概念,它允许一个对象(子对象)继承另一个对象(父对象)的属性和方法。在JavaScript中,由于其动态类型和基于原型的特性,实现继承的方式比传统的面向对象语言更为灵活,但...
在给定的文件内容中,我们看到一个具体的JavaScript继承的例子,主要分为以下几个步骤: 1. 定义父类`Person`,这个类有一个原型方法`walk`和`sayHello`,它们分别用于定义行走和打招呼的行为。 ```javascript ...
JavaScript继承是面向对象编程(OOP)中的一个核心概念,它允许一个对象(称为子类或派生类)继承另一个对象(称为父类或基类)的属性和方法。JavaScript是一种基于原型的编程语言,它实现继承的方式与其他基于类的...
JavaScript 中继承的实现 怎么建? git clone 这个仓库 切换到新目录 npm install npm run build 用法 var Person = BaseObject . extend ( { init : function ( name , age ) { this . name = name ; this . ...
JavaScript中的继承是一个核心概念,它在面向对象编程中扮演着至关重要的角色。与其他面向对象语言相比,JavaScript的继承机制更为复杂。在Java或C++等语言中,继承通常只需要一个关键字,如`extends`,但在...
详细介绍了JavaScript中继承的实现方式以及其优缺点分析。
寄生组合继承解决了组合继承中父类构造函数会被调用两次的问题,通过创建父类的一个不被使用的实例,然后将子类的原型指向这个实例的原型。 ```javascript function inheritPrototype(subType, superType) { let ...
在JavaScript中,选择合适的继承方式取决于具体需求。理解并熟练掌握这些继承方式,能让你在编写代码时更加游刃有余。文章中的`inheritance.html`和`inheritance.js`文件可能包含示例代码,帮助你直观地了解每种继承...
在这个主题中,“javascript控件开发之继承关系”主要探讨的是如何利用JavaScript的面向对象特性来构建和组织控件的层次结构,以及如何通过继承来实现代码的复用和模块化。 在JavaScript中,继承是基于原型...
JavaScript中的类继承是一种模拟传统面向对象编程中类概念的方式,因为JavaScript本身是一种基于原型的面向对象语言。在JavaScript中,对象可以直接从其他对象继承属性和方法,而不是通过类的实例化。这种继承机制...
在原型链继承中,子类型的原型对象指向父类型的实例,从而使得子类型的实例可以继承父类型原型上的属性和方法。原型链继承允许子类型访问父类型的实例属性和方法,这在JavaScript中是通过设置子类型的prototype指向...
JavaScript中的原型继承是一种基于原型(Prototype)的继承机制,它不同于传统的类继承,而是通过对象之间的关联来实现对象间的共享属性和方法。在JavaScript中,每个函数都有一个`prototype`属性,这个属性是一个...
本文将详细介绍六种实现JavaScript继承的方法。 1. 原型链继承 原型链继承是通过改变子类型的原型对象来实现继承的。子类型构造函数的原型被替换为超类型构造函数的一个实例,这样子类型就可以继承超类型的所有属性...
JavaScript 中的继承机制是指子类继承父类的属性和方法,使得子类可以拥有父类的所有特征。继承是面向对象编程的基本机制之一,它可以实现代码复用、提高编程效率和增强代码的可维护性。 在 JavaScript 中,继承是...
在JavaScript中,原型继承是一种非常核心且独特的机制,它使得对象能够继承其他对象的属性和方法。本文旨在深入探讨这一机制,并通过具体的示例代码帮助读者更好地理解其中的概念。 #### 二、基本概念 在JavaScript...
在本文中,我们将深入探讨JavaScript继承机制的实现方式,并对基于原型的继承、构造函数方式继承、组合继承、寄生式继承等继承机制进行了总结归纳和分析。 基于原型的继承 JavaScript是一门基于原型的语言,它不像...