javascript的继承方法

一、构造函数继承

  该方法最简单,使用call或者apply方法,将父对象的构造函数绑定到子对象上。

function Parent(name){
    this.name = name;
    this.color = [‘red‘,‘green‘];
        this.getInfo = function(){
        alert(this.name + ‘喜欢的颜色:‘+ this.color)
    }
}

function Child(name){
    Parent.call(this,name);
}

var child1 = new Child(‘张三‘);
child1.color.push(‘black‘);
child1.getInfo();// 张三喜欢的颜色: red,green,black
var child2 = new Child(‘李四‘);
child2.getInfo();    // 李四喜欢的颜色: red,green

这样实现有一个弊端,就是每new一次,实例对象的属性和方法都会开辟内存空间,比较浪费内存,缺乏效率。

为了解决内存消耗问题,下面介绍一下原型链继承

二、原型链继承

  我们知道每一个构造函数都有一个prototype属性,指向另一个对象。这个对象的所有方法和属性都会被构造函数的实例继承。所以我们可以把不变的属性和方法定义在prototype对象上。

  

function Parent(name){
	this.name = name;
	this.color = [‘red‘,‘green‘];
}
//不变的属性或方法定义在prototype上,prototype对象上的方法是共享的, 每次new Parent()时不需要重新开辟内存空间
Parent.prototype.getInfo = function(){
	alert(this.name + ‘喜欢的颜色:‘+ this.color)
}
function Child(name){
}
Child.prototype = new Parent();

var child1 = new Child(‘张三‘);

child1.color.push(‘black‘);  //此操作会改变Parent构造函数的color属性 color值变成[red,green,black] 

child1.getInfo(); //undefined喜欢的颜色 : red,green,black 

var child2 = new Child(‘李四‘); 

child2.getInfo();//undefined喜欢的颜色 : red,green,black ,

  

原型链继承存虽然解决了构造函数消耗内存的问题,但是这种继承方式存在两个问题:

  问题1: 创建子类型的实例时,无法向父类构造函数传递参数(例子中:Childh的name参数无法传给Parent中)。

  问题2:如果构造行数的属性是引用类型,并且集成后改变了其值,则父构造函数中得值会被更改(例子中的color属性被更改了)

三、混合继承(构造函数和原型结合方式)

  借鉴以上两种方式的优缺点,采用构造函数和原型结合方式

function Parent(name){
	this.name = name;
	this.color = [‘red‘,‘green‘];
}
//不变的属性或方法定义在prototype上,prototype对象上的方法是共享的, 每次new Parent()时不需要重新开辟内存空间
Parent.prototype.getInfo = function(){
	alert(this.name + ‘喜欢的颜色:‘+ this.color)
}
function Child(name){
	//通过call或者apply实现继承Parent,相当于重新创建了Parent属性的副本
	//Parent中的属性会copy出一份,重新开辟内存空间
	Parent.call(this,name);
	//Parent.apply(this,[name]);
}
Child.prototype = new Parent();

var child1 = new Child(‘张三‘);
child1.color.push(‘black‘);
child1.getInfo(); //张三喜欢的颜色 : red,green,black
var child2 = new Child(‘李四‘);
child2.getInfo();//李四喜欢的颜色 : red,green

  

时间: 2024-08-06 20:02:17

javascript的继承方法的相关文章

javascript实现继承方法

javascript继承概念:js是基于对象的,他没有类的概念,所以实现继承,需要使用js的原型prototype机制或者用applay和call方法实现 1.原型链继承 为了让子类继承父类的属性(也包括方法),首先需要定义一个构造函数.然后,将父类的新实例赋值给构造函数的原型. function parent(){ this.name="garuda"; } function child(){ this.sex="man" } child.prototype=ne

JavaScript中继承的主要方法

1. 原型链继承 子类使用基类对象重写prototype function SuperType(){ this.property = true; } SuperType.prototype.getSuperValue = function(){ return this.property; }; function SubType(){ this.subproperty = false; } //inherit from SuperType SubType.prototype = new Super

浅谈JavaScript中继承的实现

  谈到js中的面向对象编程,都有一个共同点,选择原型属性还是构造函数,两者各有利弊,而就片面的从js的对象创建以及继承的实现两个方面来说,官方所推荐的是两个相结合,各尽其责,各取其长,在前面的例子中,我已就在JavaScript中对象创建的方法做了一些总结,下面就其继承来道说一二:   1:原型链继承: 每一个构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而实例都包含一个指向原型对象内部的指针(默认的原型,所有默认类型都继承了Object,而这个继承也是用过原型链实现) fu

js oop中的三种继承方法

JS OOP 中的三种继承方法: 很多读者关于js opp的继承比较模糊,本文总结了oop中的三种继承方法,以助于读者进行区分. <继承使用一个子类继承另一个父类,子类可以自动拥有父类的属性和方法.(继承的两方,发生在两个类之间)> 一.通过object实现继承 1:定义父类 function Parent(){} 2:定义子类 funtion Son(){} 3:通过原型给Object对象添加一个扩展方法. Object.prototype.customExtend = function(p

浅谈JavaScript的继承

我想我的JavaScript的基本语法基础掌握的差不多了,现在没时间,毕竟那么多考试等着我.等到寒假我就把犀牛书过一遍. 本来就有那么多考试,但是我还是忍不住写点JavaScript的代码.我认为我的基础差不多了,我就把那本<JavaScript设计模式>拿出来看,我之前是看不懂的. 然后我想我现在应该看得懂了吧.就特意找了继承这一章看一看. ——————————————————————我是厉害的分割线———————————————————————————————————————— 只能说勉强

JavaScript核心-继承-原型链

继承是面向对象的编程的一大特性,很多OO语言都支持两种继承方式:接口继承和实现继承.在ECMAScript中,由于函数没有签名,所以无法实现接口继承,只有实现继承. 实现继承主要是依靠原型链来实现的. 简单回顾一下构造函数.原型和实例的关系:每个构造函数都有一个原型对象,原型对象都包含一个指向构造函数的指针,而对象的每个实例都有一个指向原型对象的内部指针. 再回顾一下原型对象的用途:用途是包含可以由特定类型的所有实例共享的属性和方法. 原型对象也是一个简单的对象,如果我们让一个原型对象等于另一个

javascript类继承

function extend(subClass, superClass) { var f = function() {}; f.prototype = superClass.prototype; subClass.prototype = new f(); subClass.superClass = superClass.prototype; } var parent = function (name, age) { this._name = name; this._age = age; };

【转载】Javascript原型继承-学习笔记

阮一峰这篇文章写的很好 http://www.ruanyifeng.com/blog/2011/06/designing_ideas_of_inheritance_mechanism_in_javascript.html 笔记如下: 一直很难理解Javascript语言的继承机制. 它没有"子类"和"父类"的概念,也没有"类"(class)和"实例"(instance)的区分,全靠一种很奇特的"原型链"(p

javascript中继承的实现

不同于基于类的编程语言,如 C++ 和 Java,JavaScript 中的继承方式是基于原型的.同时由于 JavaScript 是一门非常灵活的语言,其实现继承的方式也非常多. 首要的基本概念是关于构造函数和原型链的,父对象的构造函数称为Parent,子对象的构造函数称为Child,对应的父对象和子对象分别为parent和child. 对象中有一个隐藏属性[[prototype]](注意不是prototype),在 Chrome 中是__proto__,而在某些环境下则不可访问,它指向的是这个