- 浏览: 506939 次
- 性别:
- 来自: 大连->北京
文章分类
最新评论
-
春天好:
写的很不错 推荐一个免费好用的云端爬虫开发平台不需要安装环境, ...
web爬虫 -
cpu88:
网络爬虫爬来爬去,网上信息可以瞬间扩散,但是也意味着,没有人愿 ...
web爬虫 -
biaoming:
牛。。学习了。。
MongoDB 关于索引的建议 -
biaoming:
楼主用mongo好早啊。
MongoDB 优化 -
biaoming:
好教程,学习了。。。
MongoDB 优化
关于继承前言
到这里如果看完函数-》对象-》Prototype,已经能应用Javascript了。但是想用面向对象的思想来编程,还差一点,那就是继承。
Prototype Chaining
让我们用默认的方法来实现继承。
前面的教程我们知道了每个函数都有prototype属性,当函数被new操作符调用,一个对象就被创建了并且这个对象关联到了prototype对象。是怎样关联的?其实是通过_proto_(在有些环境叫_proto_),通过它的链接就可以使新建的对象访问prototype对象了。
prototype本身就是个对象,因此它也可以链接到自身的prototype,也就是Prototype链。
Prototype Chaining的例子
用prototype chaining实现继承,先定义三个构造函数
function Shape(){ this.name = 'shape'; this.toString = function() {return this.name;}; } function TwoDShape(){ this.name = '2D shape'; } function Triangle(side, height) { this.name = 'Triangle'; this.side = side; this.height = height; this.getArea = function(){return this.side * this.height / 2;}; }
看看怎么样来实现继承
TwoDShape.prototype = new Shape(); Triangle.prototype = new TwoDShape();
TwoDShape.prototype.constructor = TwoDShape; Triangle.prototype.constructor = Triangle;
让我们来测试下
var my = new Triangle(5, 10); my.getArea();//25
上面的代码没什么可以证明继承的关系。本身getArea函数就是有Triangle自身定义的。看看下面的代码
my.toString();//Triangle
虽然my对象并没有toString的方法,但是它继承了Shape.就可以调用toString的方法了。
让我们看看javascript引擎是怎样工作的.
- 首先先循环my对象的属性,发现没有toString的方法。
- 通过_proto_的链接找到对象,也就是TwoDShape()创建的对象。
- 接下来又开始循环TwoDShape的实例,发现也没有toString的方法。然后又会检查_proto_指向的对象。也就是Shape创造的对象。
- 终于在Shape的实例中,找到了toString方法。
- 最终toString方法在my的上下文中被调用。意思就是this指向了my对象。
再让我们来看看my的构造函数是什么
my.constructor ;//Triangle(side,height)
可以用instanceof 来验证 my是否属于三个构造函数的实例
my instanceof Shape//true my instanceof TwoDShape//true my instanceof Triangle//true my instanceof Array//false
也可以用isPrototypeOf。结果相同。
Shape.prototype.isPrototypeOf(my) //true TwoDShape.prototype.isPrototypeOf(my) //true Triangle.prototype.isPrototypeOf(my) //true String.prototype.isPrototypeOf(my) //false
同样的我们在创建两个对象和上面的例子都一样
var td = new TwoDShape(); td.constructor//TwoDShape var s = new Shape(); s.constructor//Shape
把共享的属性添加到Prototype中
当创建一个构造函数的时候,自身的属性添加都用this.看个例子
function Shape(){ this.name = 'shape'; }
当这样定义name的时候,也就是用Shape构造函数每创建一个函数都会在内存中创建一个name属性。另一个方法就是把name属性添加到prototype属性中,并共享所有的实例。
function Shape(){} Shape.prototype.name = 'shape';
这种情况的时候,每创建一个对象就不会有自身的属性name了。但是可以用prototype的name属性。
看个更深的例子,
function Shape(){} // 扩展prototype Shape.prototype.name = 'shape'; Shape.prototype.toString = function() {return this.name;}; function TwoDShape(){} // 继承之前不要扩展prototype TwoDShape.prototype = new Shape(); TwoDShape.prototype.constructor = TwoDShape; // 继承之后再扩展 TwoDShape.prototype.name = '2D shape';
以上的程序要小心的是,TwoDShape继承之前不要扩展它的prototype。也就是继承之前扩展prototype都是无效的 了。(详情请看prototype的学习).
Triangle的构造函数还是和其他有点不同,本身每次创建一个Triangle都会有很多不同的面积。因此把side和height属性作为自身变量是可行的。代码如下:
function Triangle(side, height) { this.side = side; this.height = height; } Triangle.prototype = new TwoDShape(); Triangle.prototype.constructor = Triangle; Triangle.prototype.name = 'Triangle'; Triangle.prototype.getArea = function(){return this.side * this.height / 2;};
测试代码都很正常
var my = new Triangle(5, 10); my.getArea();//25 my.toString();//Triangle
评论
http://xiayuanfeng.iteye.com/admin/blogs/307152
2.自我感觉用扩展是可以的啊。我是相对TwoDShape.prototype可能造成误会。。
谢谢提问。
# TwoDShape.prototype.constructor = TwoDShape;
# Triangle.prototype.constructor = Triangle;
如果这两句不加的话,依次执行下来,那么执行到下面的语句,值是否是下面这样。
# var td = new TwoDShape();
# td.constructor//TwoDShape===========》//Shape
# var s = new Shape();
# s.constructor//Shape============》//Shape
2.
1. function Shape(){}
2. // 扩展prototype
3. Shape.prototype.name = 'shape';
4. Shape.prototype.toString = function() {return this.name;};
5. function TwoDShape(){}
6. // 继承之前不要扩展prototype
7. TwoDShape.prototype = new Shape();
8. TwoDShape.prototype.constructor = TwoDShape;
9. // 继承之后再扩展
10. TwoDShape.prototype.name = '2D shape';
第10行,我感觉这个应该不是扩展,因为TwoDShape本身就有name属性,用的是TwoDShape里的name,不是Shape里的name,这句只是重新给TwoDShape里的name赋值罢了。
只是一些疑问,望楼主解答。。
# TwoDShape.prototype.constructor = TwoDShape;
# Triangle.prototype.constructor = Triangle;
如果这两句不加的话,依次执行下来,那么执行到下面的语句,值是否是下面这样。
# var td = new TwoDShape();
# td.constructor//TwoDShape===========》//Shape
# var s = new Shape();
# s.constructor//Shape============》//Shape
2.
1. function Shape(){}
2. // 扩展prototype
3. Shape.prototype.name = 'shape';
4. Shape.prototype.toString = function() {return this.name;};
5. function TwoDShape(){}
6. // 继承之前不要扩展prototype
7. TwoDShape.prototype = new Shape();
8. TwoDShape.prototype.constructor = TwoDShape;
9. // 继承之后再扩展
10. TwoDShape.prototype.name = '2D shape';
第10行,我感觉这个应该不是扩展,因为TwoDShape本身就有name属性,用的是TwoDShape里的name,不是Shape里的name,这句只是重新给TwoDShape里的name赋值罢了。
只是一些疑问,望楼主解答。。
发表评论
-
Javascript 基本数据类型,数组,循环以及条件 - 基本数据类型
2009-10-13 09:43 0你所使用的任意值都包含一个类型。在javascript中有如下 ... -
Javascript 基本数据类型,数组,循环以及条件 - 运算符
2009-10-12 21:41 1380运算符 运算符对一个或两个值(也可能是变量),进行一个 ... -
Javascript 基本数据类型,数组,循环以及条件-变量
2009-10-12 21:39 1876在深入javascript面向对象特性之前,让我们温习下基础知 ... -
Javascript 在浏览器环境中 (七) XMLHttpRequest
2009-02-17 17:19 2524XMLHttpRequest XMLHttpRequest是一 ... -
Javascript 在浏览器环境中 (六) 事件
2009-02-17 14:17 2656事件 事件的例子很多了。如用户输入,点击按钮等等。可以把一个j ... -
Javascript 在浏览器环境中 (五) HTML DOM
2009-02-12 13:56 1755已经知道了 DOM 适用于 XML和HTML文档。前几部分已经 ... -
Javascript 在浏览器环境中 (四) DOM节点的创建,修改与删除
2009-02-12 13:55 5989修改节点 上面一篇我们学习了DOM节点的访问,下面来看看DO ... -
Javascript 在浏览器环境中 (三) DOM节点的访问
2009-02-09 14:47 2457DOM DOM就是Document object Model的 ... -
Javascript 在浏览器环境中 (二) BOM
2009-02-05 17:25 1552BOM BOM是Browser Object Model的缩写 ... -
Javascript 在浏览器环境中 (一) 目录
2009-02-05 15:35 1332前言 大家都知道Javascript程序本身不能自己运行。需要 ... -
Javascript 继承 (七)
2009-02-05 15:21 1140混合使用原型继承和复制属性 当使用继承时,更多的是想在现有的功 ... -
Javascript 继承 (六)
2009-01-19 16:36 1107深度拷贝 上一节所说到的extendCopy再深一层的对象 ... -
Javascript 继承 (五)
2009-01-13 17:59 1151要注意复制引用。 很烦的是,在复制引用的时候,有的时候并不是期 ... -
Javascript 继承 (四)
2009-01-12 23:04 1190封装继承 通过上面的学习,我们把继承封装,这样就可复用了。代码 ... -
Javascript 继承 (三)
2009-01-06 00:33 1449从子对象中访问父对象。 经典的面向对象语言都有语法可以在子类中 ... -
Javascript 继承 (二)
2009-01-05 23:04 1442仅仅继承Prototype 添加可以重用的方法和属性到prot ... -
Javascript Prototype (二)
2008-12-30 16:59 2378穷举属性(Enumerating Properties) 要列 ... -
Javascript Prototype (一)
2008-12-30 14:22 2183关于prototype 属性 函数(functions)在ja ... -
Javascript 对象 (四)
2008-12-29 16:20 1043函数返回对象 可以用构造函数来创建个对象,也可以通过普通函数返 ... -
Javascript 对象 (三)
2008-12-29 15:33 1131This var hero = { name : 'Ra ...
相关推荐
JavaScript中的继承是一个核心概念,它在面向对象编程中扮演着至关重要的角色。与其他面向对象语言相比,JavaScript的继承机制更为复杂。在Java或C++等语言中,继承通常只需要一个关键字,如`extends`,但在...
原型链是JavaScript继承机制的核心,它允许一个对象从另一个对象中继承属性和方法。通过原型链,JavaScript可以实现多重继承,这使得JavaScript的继承机制更加灵活和强大。 构造函数方式继承 构造函数方式继承是一...
本篇文章将深入探讨JavaScript实现继承的七种常见方式,帮助你更好地理解和运用这一概念。 1. 原型链继承(Prototype Chain Inheritance) 原型链是JavaScript实现继承的基础。每个函数都有一个`prototype`属性,这...
本文将深入探讨JavaScript继承的实现方式,以及其中的问题和解决方案。 首先,我们来看混合方式的实现,这种方式结合了原型链和对象冒充。在JavaScript中,构造函数是用于创建特定类型对象的函数。例如,`Employee`...
JavaScript 继承之为什么要继承 JavaScript 中的继承机制是指子类继承父类的属性和方法,使得子类可以拥有父类的所有特征。继承是面向对象编程的基本机制之一,它可以实现代码复用、提高编程效率和增强代码的可维护...
这里我们将深入探讨JavaScript继承的特性以及实践应用。 首先,JavaScript的继承基于原型链。每个对象都有一个`__proto__`属性,指向创建它的构造函数的原型对象。当试图访问对象的一个属性时,JavaScript会沿着...
JavaScript中的继承是面向对象编程的重要概念,它允许一个对象(子对象)获取另一个对象(父对象)的属性和方法,从而实现代码复用和多态性。JavaScript支持多种继承实现方式,包括以下四种: 1. **构造函数继承**...
JavaScript是一种广泛应用于网页和网络应用的脚本语言,尤其在前端开发中占据核心地位。控件开发是JavaScript应用中的重要部分,它涉及到UI组件的创建和功能实现。在这个主题中,“javascript控件开发之继承关系”...
继承是面向对象的核心特性之一,它允许一个对象(子类)从另一个对象(父类)获取属性和方法,从而形成类之间的层次结构。本篇文章将深入探讨JavaScript中实现继承的几种常见方式。 1. 原型链继承 JavaScript的原型...
在本章中,我们将分析Prototypejs中关于JavaScript继承的实现。 Prototypejs是最早的JavaScript类库,可以说是JavaScript类库的鼻祖。 我在几年前接触的第一个JavaScript类库就是这位,因此Prototypejs有着广泛的...
JavaScript继承机制探讨及其应用 JavaScript是一门弱类型语言,具有函数式编程和面向对象编程的特点。随着近几年JavaScript生态圈的发展和成熟,项目的编码量和复杂度也在呈几何级数增长。JavaScript面向对象编程中...
在JavaScript中,继承是面向对象编程的一个核心概念,它允许我们创建基于现有对象的新对象,同时还能继承其属性和方法。本篇将深入探讨一种实现继承的工具函数方法,主要聚焦于`source.js`文件中可能包含的内容。...
在JavaScript中,面向对象编程是其核心特性之一,而继承和派生则是实现面向对象的重要机制。本资料集合关注的是JavaScript中的继承派生以及与之相关的`apply`和`call`方法。 **继承**是面向对象编程的关键概念,...
1. **JavaScript继承** - **原理**:JavaScript的继承主要是通过原型链(prototype chain)来实现的。每个JavaScript对象都有一个内部属性[[Prototype]],通常可以通过`__proto__`访问,或通过`Object....
ES6之前,JavaScript并没有继承这一现有的机制。 ES5的继承方式 类式继承 //声明父类 function Father(){ this.fatherVal = 'father'; } //为父类添加共有方法 Father.prototype.getFatherValue = function(){ ...
JavaScript 继承是面向对象编程中的关键概念,它允许创建基于现有对象的新对象,从而能够复用和扩展已有功能。本文将深入探讨JavaScript中的几种继承方式,包括它们的基本原理、优缺点以及适用场景。 首先,原型链...
本文将深入探讨JavaScript继承的六大模式:原型链、借用构造函数、组合继承、原型式继承、寄生式继承以及寄生组合式继承。 1. **原型链** 原型链是JavaScript中最基础的继承方式,通过原型对象的引用实现。每个...