要注意复制引用。
很烦的是,在复制引用的时候,有的时候并不是期望的结果。
让我们创建两个构造函数,给prototype添加属性
var A = function(){},B=function(){};
A.prototype.stuff=[1,2,3];//[1,2,3]
A.prototype.name='a';//a
让我们用B继承A,
extend2(B, A);
用extend2的方法,B的prototype继承A的prototype属性。
B.prototype.hasOwnProperty('name');//true
B.prototype.hasOwnProperty('stuff');//true
name属性是一个基本类型的复制,stuff属性是一个引用的复制。让我们看看如下代码
B.prototype.stuff;//[1,2,3]
B.prototype.stuff===A.prototype.stuff;//true
//改变B的name,并不会影响A
B.prototype.name+='b';//ab
A.prototype.name//a
当改变B的stuff属性时候,也会影响A的stuff属性。
但是如果你用另一个对象去覆盖了B.prototype,下列代码A指向了旧的对象,B指向了新的对象。
B.prototype.stuff = ['a', 'b', 'c'];//["a","b","c"]
A.prototype.stuff;//[1,2,3,4,5,6]
对象继承对象
前面所说的继承都是用构造函数创建的对象,我们可以用一个构造函数创建的对象去继承另一个构造函数创建的对象,然而也可以用对象文字量(object literal)去使用继承.
在java中,可以定义一个类去继承另一个类,因为类有面向对象的基本功能。在javascript并没有类,所以我们用构造函数去模拟,另外也提供了new操作符。让我们看如下代码
Child.prototype = new Parent();
Child构造函数继承与Parent,但是它紧紧继承于new Parent。看起来虽然像类继承,但是这并不是类继承。
像前面所说的属性复制继承方式,就是把一个对象的所有属性拷贝到另一个对象中。
对象可以var o={}的方式创建,这样也可以把其他对象的属性拷贝至这个对象中,代码如下:
function extendCopy(p) {
var c = {};
for (var i in p) {
c[i] = p[i];
}
c.uber = p;
return c;
}
简单的属性复制是很简单的方式,有许多开源项目都这么使用继承的。如Jquery,firebug.
让我我们看一个简单的例子。
var shape = {
name: 'shape',
toString: function() {return this.name;}
}
创建一个基于shape的对象我们可以用extendCopy的方式,这就就可以扩展子对象的功能了。
var twoDee = extendCopy(shape);
twoDee.name = '2D shape';
twoDee.toString = function(){return this.uber.toString() + ', ' +
this.name;};
triangle继承2D shape 对象。
var triangle = extendCopy(twoDee);
triangle.name = 'Triangle';
triangle.getArea = function(){return this.side * this.height / 2;}
调用triangle
triangle.side = 5;
triangle.height = 10;
triangle.getArea();//25
triangle.toString();// "shape, 2D shape, Triangle"
一点说明,这里的
triangle.side = 5;
triangle.height = 10;
可以用构造方法(这里叫方法,就像Java的类中的"函数")来赋值。可以在这个构造函数中调用一个init(side,height)来赋值初始化,很方便。
分享到:
相关推荐
除了传统的原型链继承,JavaScript还支持其他继承模式,如组合继承(组合使用构造函数和原型链)、寄生继承(通过创建父类副本改进继承)、原型式继承(使用`Object.create()`)、寄生组合式继承(被认为是最有效的...
javascript 五种继承简介。
JavaScript继承机制研究 在本文中,我们将深入探讨JavaScript继承机制的实现方式,并对基于原型的继承、构造函数方式继承、组合继承、寄生式继承等继承机制进行了总结归纳和分析。 基于原型的继承 JavaScript是...
本文将深入探讨JavaScript继承的实现方式,以及其中的问题和解决方案。 首先,我们来看混合方式的实现,这种方式结合了原型链和对象冒充。在JavaScript中,构造函数是用于创建特定类型对象的函数。例如,`Employee`...
本篇文章将深入探讨JavaScript实现继承的七种常见方式,帮助你更好地理解和运用这一概念。 1. 原型链继承(Prototype Chain Inheritance) 原型链是JavaScript实现继承的基础。每个函数都有一个`prototype`属性,这...
JavaScript 继承之为什么要继承 JavaScript 中的继承机制是指子类继承父类的属性和方法,使得子类可以拥有父类的所有特征。继承是面向对象编程的基本机制之一,它可以实现代码复用、提高编程效率和增强代码的可维护...
JavaScript中的继承是面向对象编程的重要概念,它允许一个对象(子对象)获取另一个对象(父对象)的属性和方法,从而实现代码复用和多态性。JavaScript支持多种继承实现方式,包括以下四种: 1. **构造函数继承**...
本篇文章将深入探讨JavaScript中实现继承的几种常见方式。 1. 原型链继承 JavaScript的原型(prototype)机制是实现继承的基础。每个函数都有一个prototype属性,这个属性指向一个对象,这个对象的属性和方法可以被...
在这个主题中,“javascript控件开发之继承关系”主要探讨的是如何利用JavaScript的面向对象特性来构建和组织控件的层次结构,以及如何通过继承来实现代码的复用和模块化。 在JavaScript中,继承是基于原型...
这里我们将深入探讨JavaScript继承的特性以及实践应用。 首先,JavaScript的继承基于原型链。每个对象都有一个`__proto__`属性,指向创建它的构造函数的原型对象。当试图访问对象的一个属性时,JavaScript会沿着...
在本章中,我们将分析Prototypejs中关于JavaScript继承的实现。 Prototypejs是最早的JavaScript类库,可以说是JavaScript类库的鼻祖。 我在几年前接触的第一个JavaScript类库就是这位,因此Prototypejs有着广泛的...
JavaScript继承机制探讨及其应用 JavaScript是一门弱类型语言,具有函数式编程和面向对象编程的特点。随着近几年JavaScript生态圈的发展和成熟,项目的编码量和复杂度也在呈几何级数增长。JavaScript面向对象编程中...
1. **JavaScript继承** - **原理**:JavaScript的继承主要是通过原型链(prototype chain)来实现的。每个JavaScript对象都有一个内部属性[[Prototype]],通常可以通过`__proto__`访问,或通过`Object....
ES6之前,JavaScript并没有继承这一现有的机制。 ES5的继承方式 类式继承 //声明父类 function Father(){ this.fatherVal = 'father'; } //为父类添加共有方法 Father.prototype.getFatherValue = function(){ ...
JavaScript 继承是面向对象编程中的关键概念,它允许创建基于现有对象的新对象,从而能够复用和扩展已有功能。本文将深入探讨JavaScript中的几种继承方式,包括它们的基本原理、优缺点以及适用场景。 首先,原型链...
在JavaScript中,面向对象编程是其核心特性之一,而继承和派生则是实现面向对象的重要机制。本资料集合关注的是JavaScript中的继承派生以及与之相关的`apply`和`call`方法。 **继承**是面向对象编程的关键概念,...
本文将深入探讨JavaScript继承的六大模式:原型链、借用构造函数、组合继承、原型式继承、寄生式继承以及寄生组合式继承。 1. **原型链** 原型链是JavaScript中最基础的继承方式,通过原型对象的引用实现。每个...