- 浏览: 496858 次
- 性别:
- 来自: 大连->北京
文章分类
最新评论
-
春天好:
写的很不错 推荐一个免费好用的云端爬虫开发平台不需要安装环境, ...
web爬虫 -
cpu88:
网络爬虫爬来爬去,网上信息可以瞬间扩散,但是也意味着,没有人愿 ...
web爬虫 -
biaoming:
牛。。学习了。。
MongoDB 关于索引的建议 -
biaoming:
楼主用mongo好早啊。
MongoDB 优化 -
biaoming:
好教程,学习了。。。
MongoDB 优化
仅仅继承Prototype
添加可以重用的方法和属性到prototype是非常有效率的。如果都这么做的话,为什么不仅仅继承prototype呢。也就是说我们继承prototype比继承new出来的对象要好的多。毕竟这个new的对象包含的代码并不是我们想复用的。
这样继承的优点如下,不用仅仅为了继承而创建一个对象。缩短了查找方法的时间。
更新后的集成代码如下:
function Shape(){} Shape.prototype.name = 'shape'; Shape.prototype.toString = function() {return this.name;}; function TwoDShape(){} TwoDShape.prototype = Shape.prototype;//重点 TwoDShape.prototype.constructor = TwoDShape; TwoDShape.prototype.name = '2D shape'; function Triangle(side, height) { this.side = side; this.height = height; } Triangle.prototype = TwoDShape.prototype;//重点 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
当查询toString的方法和以前的例子有什么不同么?首先,查询my对象自身的属性,发现没有,再检查prototype,要记住对象的copy并不是值的copy,而是引用。所以它们共同的prototype指向一个地址。也就是说 仅仅检查两个步骤就完成了上面复杂的检查。虽然这个方法很有效率,但是因为指向的是同一地址所以要注意以下的情况。
Triangle.prototype.name = 'Triangle'; var s = new Shape() s.name;//Triangle
临时的构造函数 new F()
上面的例子的问题还是很严重的,父对象取到子对象的属性了,必须要解决的。可以想一个中间层打破这个链。
方法就是用个临时的构造函数。
function Shape(){} Shape.prototype.name = 'shape'; Shape.prototype.toString = function() {return this.name;}; function TwoDShape(){} var F = function(){}; F.prototype = Shape.prototype; TwoDShape.prototype = new F();//注意这里 TwoDShape.prototype.constructor = TwoDShape; TwoDShape.prototype.name = '2D shape'; function Triangle(side, height) { this.side = side; this.height = height; } var F = function(){}; F.prototype = TwoDShape.prototype; Triangle.prototype = new F();//注意这里 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
var s = new Shape();
s.name;//Shape
这样就避免了上面说的问题。
评论
4 楼
kingtoon
2010-05-13
此前在博客园里看过关于prototype的讲述,了解了关于new的过程
比如 此句 "var shape = new Shape();"的执行可以分为下面几句:
所以每当new一个新的对象时 都会通过call 拷贝构造函数里的所有属性
所以通过构造中间函数F的话 如
"F.prototype = Shape.prototype; TwoDShape.prototype = new F(); "
这样 TwoDShape.prototype共享了空函数F 而F也仅仅是通过prototype共享Shape的prototype,而非Shape构造函数里的属性,因此也就让TwoDShape失去了继承Shape的构造函数的所有属性的可能.
比如 此句 "var shape = new Shape();"的执行可以分为下面几句:
var shape = function(){}; shape.__proto__ = Shape.prototype; Shape.call(shape);
所以每当new一个新的对象时 都会通过call 拷贝构造函数里的所有属性
所以通过构造中间函数F的话 如
"F.prototype = Shape.prototype; TwoDShape.prototype = new F(); "
这样 TwoDShape.prototype共享了空函数F 而F也仅仅是通过prototype共享Shape的prototype,而非Shape构造函数里的属性,因此也就让TwoDShape失去了继承Shape的构造函数的所有属性的可能.
3 楼
kingtoon
2010-05-11
还有一个 这样实现继承和之前的继承还是有区别的.之前的继承是一层层继承的.而加入临时空函数F的话 子类只能是继承父类的prototype熟悉了.
比如说三个函数A,B,C.之前的继承可以实现:C继承B,B继承A,C可以完全继承B的所有属性,在此基础上也可以完全继承A的所有属性,因为这是一个完整的链;而如果加入F的话,就只有父类的prototype链对象了.如例子中:只能是C继承B的prototype和A的prototype,B继承A的prototype属性.C不能继承B的构造函数属性和A的构造函数属性,及B也不能继承A的构造函数属性.
比如在:function TwoDShape(){this.nickname = '2d';};
这样,子类Triangle不能继承TwoDShape的nickname属性.
不过楼主的讲解 让我更加深刻理解JavaScript了
很早就知道JavaScript 但一直都没去进一步了解熟悉她.
楼主的JavaScript讲解 个人感觉还是很不错的 我会继续关注 呵呵
比如说三个函数A,B,C.之前的继承可以实现:C继承B,B继承A,C可以完全继承B的所有属性,在此基础上也可以完全继承A的所有属性,因为这是一个完整的链;而如果加入F的话,就只有父类的prototype链对象了.如例子中:只能是C继承B的prototype和A的prototype,B继承A的prototype属性.C不能继承B的构造函数属性和A的构造函数属性,及B也不能继承A的构造函数属性.
比如在:function TwoDShape(){this.nickname = '2d';};
这样,子类Triangle不能继承TwoDShape的nickname属性.
不过楼主的讲解 让我更加深刻理解JavaScript了
很早就知道JavaScript 但一直都没去进一步了解熟悉她.
楼主的JavaScript讲解 个人感觉还是很不错的 我会继续关注 呵呵
2 楼
kingtoon
2010-05-11
对于定义两次空函数有些不解 就直接定义一次就可以的 如下面:
function Shape(){};
Shape.prototype.name = 'Shape';
Shape.prototype.toString = function(){return this.name};
function F(){};
F.prototype = Shape.prototype;
function TwoDShape(){};
//TwoDShape.prototype = Shape.prototype;
TwoDShape.prototype = new F();
TwoDShape.prototype.constructor = TwoDShape;
TwoDShape.prototype.name = '2d Shape';
function Triangle(side, height){
this.side = side;
this.height = height;
};
//Triangle.prototype = TwoDShape.prototype;
Triangle.prototype = new F();
Triangle.prototype.constructor = Triangle;
Triangle.prototype.name = 'Triangle';
Triangle.prototype.getArea = function(){ return this.side * this.height / 2 ;};
function Shape(){};
Shape.prototype.name = 'Shape';
Shape.prototype.toString = function(){return this.name};
function F(){};
F.prototype = Shape.prototype;
function TwoDShape(){};
//TwoDShape.prototype = Shape.prototype;
TwoDShape.prototype = new F();
TwoDShape.prototype.constructor = TwoDShape;
TwoDShape.prototype.name = '2d Shape';
function Triangle(side, height){
this.side = side;
this.height = height;
};
//Triangle.prototype = TwoDShape.prototype;
Triangle.prototype = new F();
Triangle.prototype.constructor = Triangle;
Triangle.prototype.name = 'Triangle';
Triangle.prototype.getArea = function(){ return this.side * this.height / 2 ;};
1 楼
kingtoon
2010-05-11
用个临时的构造函数 实现继承 更复杂了
发表评论
-
Javascript 基本数据类型,数组,循环以及条件 - 基本数据类型
2009-10-13 09:43 0你所使用的任意值都包含一个类型。在javascript中有如下 ... -
Javascript 基本数据类型,数组,循环以及条件 - 运算符
2009-10-12 21:41 1339运算符 运算符对一个或两个值(也可能是变量),进行一个 ... -
Javascript 基本数据类型,数组,循环以及条件-变量
2009-10-12 21:39 1832在深入javascript面向对象特性之前,让我们温习下基础知 ... -
Javascript 在浏览器环境中 (七) XMLHttpRequest
2009-02-17 17:19 2472XMLHttpRequest XMLHttpRequest是一 ... -
Javascript 在浏览器环境中 (六) 事件
2009-02-17 14:17 2593事件 事件的例子很多了。如用户输入,点击按钮等等。可以把一个j ... -
Javascript 在浏览器环境中 (五) HTML DOM
2009-02-12 13:56 1708已经知道了 DOM 适用于 XML和HTML文档。前几部分已经 ... -
Javascript 在浏览器环境中 (四) DOM节点的创建,修改与删除
2009-02-12 13:55 5931修改节点 上面一篇我们学习了DOM节点的访问,下面来看看DO ... -
Javascript 在浏览器环境中 (三) DOM节点的访问
2009-02-09 14:47 2417DOM DOM就是Document object Model的 ... -
Javascript 在浏览器环境中 (二) BOM
2009-02-05 17:25 1510BOM BOM是Browser Object Model的缩写 ... -
Javascript 在浏览器环境中 (一) 目录
2009-02-05 15:35 1298前言 大家都知道Javascript程序本身不能自己运行。需要 ... -
Javascript 继承 (七)
2009-02-05 15:21 1100混合使用原型继承和复制属性 当使用继承时,更多的是想在现有的功 ... -
Javascript 继承 (六)
2009-01-19 16:36 1075深度拷贝 上一节所说到的extendCopy再深一层的对象 ... -
Javascript 继承 (五)
2009-01-13 17:59 1121要注意复制引用。 很烦的是,在复制引用的时候,有的时候并不是期 ... -
Javascript 继承 (四)
2009-01-12 23:04 1157封装继承 通过上面的学习,我们把继承封装,这样就可复用了。代码 ... -
Javascript 继承 (三)
2009-01-06 00:33 1407从子对象中访问父对象。 经典的面向对象语言都有语法可以在子类中 ... -
Javascript 继承 (一)
2008-12-31 15:32 1389关于继承前言 到这里如 ... -
Javascript Prototype (二)
2008-12-30 16:59 2298穷举属性(Enumerating Properties) 要列 ... -
Javascript Prototype (一)
2008-12-30 14:22 2148关于prototype 属性 函数(functions)在ja ... -
Javascript 对象 (四)
2008-12-29 16:20 1014函数返回对象 可以用构造函数来创建个对象,也可以通过普通函数返 ... -
Javascript 对象 (三)
2008-12-29 15:33 1097This var hero = { name : 'Ra ...
相关推荐
在JavaScript中继承是一个非常复杂的话题,比其他任何面向对象的语言中的继承都复杂得多。在大多数其他面向对象语言中,继承一个类只需使用一个关键字即可。与它们不同,在JavaScript中要想达到传承公用成员的目的,...
Javascript继承机制原理 可以参考下
浅析Javascript原型继承,浅析Javascript原型继承
javascript控件开发之继承关系的源码
JavaScript继承与多继承实例分析.docx
JavaScript继承的三种方法实例 继承 继承: 首先继承是一种关系,类(class)与类之间的关系,JS中没有类,但是可以通过构造函数模拟类,然后通过原型来实现继承。 继承也是为了数据共享,js中的继承也是为了实现...
javascript继承之为什么要继承.docx
javascript 继承派生等问题的资料,都是网上收集的,学会apply call 就懂js面向对象的原理了。
JavaScript继承机制研究.pdf
理解Javascript原型继承原理
javascript 五种继承简介。
javascript原型继承,prototype的使用,可以像java一样继承
Javascript继承[参考].pdf
JavaScript Inheritance ...And you think you’re so clever ...JavaScript的原型继承比类继承有更强大的表现力,现在就让我们来看看。 Java JavaScript 强类型 弱类型 静态 动态 基于类 基于原型 类
Javascript原型继承Javascript原型继承Javascript原型继承
浅析javascript原型继承机制,浅析javascript原型继承机制
JavaScript继承机制探讨及其应用.pdf
我们还知道,面向对象编程有三个重要的概念 - 封装、继承和多态。 但是在JavaScript的世界中,所有的这一切特性似乎都不存在。 因为JavaScript本身不是面向对象的语言,而是基于对象的语言。
NULL 博文链接:https://snandy.iteye.com/blog/429140
JavaScript面向对象编程中使用继承,详细讲解四种实现方法的原理。