码迷,mamicode.com
首页 > 其他好文 > 详细

【笔记】封装可使用的构造函数继承

时间:2015-01-15 10:56:38      阅读:163      评论:0      收藏:0      [点我收藏+]

标签:

读书笔记《javascript面向对象编程指南》


(YUI)库所用的方法:


function extend(Child, Parent) {

    var F = function(){};

    F.prototype = Parent.prototype;

    Child.prototype = new F();

    Child.prototype.constructor = Child;

    Child.uber = Parent.prototype;

  }



另外还有一种拷贝继承方法,属性拷贝:

这种方法与之前的不同,由于已经完成对child的原型进行扩展,不需要再重置child.prototype.constructor属性了,因为它不会再被覆盖。

与之前的方法相比,这个方法在效率上显然略孙一筹。因为这里执行的是对子对象原型的逐一拷贝。而非简单的原型链查询。

这种方式仅适用只包含基本数据类型的对象,所有的对象类型包括函数和数组,都是不可复制的,他们只支持引用传递。


function extend2(Child, Parent) {

    var p = Parent.prototype;

    var c = Child.prototype;

    for (var i in p) {

      c[i] = p[i];

      }

    c.uber = p;

  }



var Shape = function(){}

var TwoDShape = function(){}

Shape.prototype.name = ‘shape‘;

Shape.prototype.toString = function(){

 return this.name;

}

extend2(TwoDShape,Shape);

var t = new TwoDShape();

t.name

//-->"shape"

t.toString();

//-->"shape"

TwoDShape.prototype.name = ‘TwoDShape‘;

t.name

//-->"2d shape"

t.toString();

//-->"2d shape"


TwoDShape.prototype.toString === Shape.prototype.toString

//-->true

TwoDShape.prototype.name === Shape.prototype.name

//-->false



【笔记】封装可使用的构造函数继承

标签:

原文地址:http://blog.csdn.net/wuweitiandian/article/details/42738095

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!