您的位置: 首页 > 技术文档 > 网页制作 > 重温Javascript继承机制
:nth-child 和 :nth-type-of 的区别 回到列表 有用的:nth-child秘方
 重温Javascript继承机制

作者:瓜瓜 时间: 2011-07-04 文档类型:合作网站提供 来自:阿里妈妈UED

第 1 页 重温Javascript继承机制 [1]
第 2 页 重温Javascript继承机制 [2]
第 3 页 重温Javascript继承机制 [3]
第 4 页 重温Javascript继承机制 [4]

三、构造函数如何实现继承

现在有一个”MED”对象的构造函数(MED:Marketing Experience Design,营销体验设计)

function MED(){
 this.aim = "营销体验设计";
}

依然是”WD”对象的构造函数,

function WD(skill,sex){
 this.skill = skill;
 this.sex = sex;
}

怎样才能使”WD”继承”MED”呢?

1. apply绑定构造函数实现

最简单的方法,大概就是使用call或apply方法,将父对象的构造函数绑定在子对象上,也就是在子对象构造函数中加一行:

function WD(skill,sex){

 MED.apply(this, arguments);

 this.skill = skill;
 this.sex = sex;
}

var WD1 = new WD("Html","男");
console.log(WD1.aim); // "营销体验设计"

2. prototype模式实现

我们通常的做法是使用prototype属性。如果”WD”的prototype对象,指向一个MED的实例,那么所有”WD”的实例,就能继承MED了。

WD.prototype = new MED();//我们将WD的prototype对象指向一个MED的实例。
WD.prototype.constructor = WD;
var WD1 = new WD("Html","男");
console.log(WD1.aim); // 营销体验设计

这句

WD.prototype = new MED();

相当于完全删除了prototype 对象原先的值,然后赋予一个新值。那么第二行又是什么意思呢?

WD.prototype.constructor = WD;

原来,任何一个prototype对象都有一个constructor属性,指向它的构造函数。也就是说,WD.prototype 这个对象的constructor属性,是指向WD的。
我们在前一步已经删除了这个prototype对象原来的值,所以新的prototype对象没有constructor属性,需要我们手动加上去,否则后面的”继承链”会出问题。这就是第二行的意思。
注意,这是很重要的一点,编程时务必要遵守,下文都遵循这一点,即如果替换了prototype对象,

o.prototype = {};

那么,下一步必然是为新的prototype对象加上constructor属性,并将这个属性指回原来的构造函数。

o.prototype.constructor = o;

3. 从prototype直接继承实现

由于MED对象中,不变的属性都可以直接写入MED.prototype。所以,我们也可以让WD()跳过 MED(),直接继承MED.prototype。
现在,我们先将MED对象改写:

function MED(){ }

MED.prototype.skill = "MED";

然后,将WD的prototype对象指向MED的prototype对象,这样就完成了继承。

WD.prototype = MED.prototype;
WD.prototype.constructor = WD;

var WD1 = new WD("Html","男");

console.log(WD1.skill); // MED

与前一种方法相比,这样做的优点是效率比较高(不用执行和建立MED的实例了),比较省内存。缺点是 WD.prototype和MED.prototype现在指向了同一个对象,那么任何对WD.prototype的修改,都会反映到MED.prototype。
所以,上面这一段代码其实是有问题的。请看第二行

WD.prototype.constructor = WD;

这一句实际上把MED.prototype对象的constructor属性也改掉了!

console.log(MED.prototype.constructor); // WD

4. 利用一个空对象作为中介来实现

由于”直接继承prototype”存在上述的缺点,所以可以利用一个空对象作为中介。

var F = function(){};
F.prototype = MED.prototype;

WD.prototype = new F();
WD.prototype.constructor = WD;

F是空对象,所以几乎不占内存。这时,修改WD的prototype对象,就不会影响到MED的prototype对象。

console.log(MED.prototype.constructor); // MED

5.利用 prototype模式的封装函数

我们将上面的方法,封装成一个函数,便于使用。

function extend(Child, Parent) {

 var F = function(){};

 F.prototype = Parent.prototype;
 Child.prototype = new F();
 Child.prototype.constructor = Child;
}

使用的时候,方法如下

extend(WD,MED);
var WD1 = new WD("Html","男");
console.log(WD1.aim); // 营销体验设计

这个extend函数就是YUI库如何实现继承的方法。

6. 拷贝继承实现

上面是采用prototype方式来实现继承。其实既然子对象会拥有父对象的属性和方法,我们直接采用”拷贝”方法也可以达到效果。简单说,如果把父对象的所有属性和方法,拷贝进子对象,不也能够实现继承吗?
首先,还是把MED的所有不变属性,都放到它的prototype对象上。

function MED(){}

MED.prototype.aim = "营销体验设计";

然后,再写一个函数,实现属性拷贝的目的。

function extendCopy(Child, Parent) {
 var p = Parent.prototype;
 var c = Child.prototype;
 for (var i in p) {
  c[i] = p[i];
 }
}

这个函数的作用,就是将父对象的prototype对象中的属性,一一拷贝给Child对象的prototype对象。
使用的时候,这样写:

extendCopy(WD, MED);
var WD1 = new WD("Html","男");
console.log(WD1.aim); // 营销体验设计

出处:阿里妈妈UED
责任编辑:bluehearts

上一页 重温Javascript继承机制 [2] 下一页 重温Javascript继承机制 [4]

◎进入论坛网页制作WEB标准化版块参加讨论,我还想发表评论

相关文章 更多相关链接
再谈javascript图片预加载技术
如何编写高质量的Javascript代码
加载 Javascript 最佳实践
GC与JS内存泄露
HTML,CSS和JavaScript速查表
关键字搜索 常规搜索 推荐文档
热门搜索:CSS Fireworks 设计比赛 网页制作 web标准 用户体验 UE photoshop Dreamweaver Studio8 Flash 手绘 CG
站点最新 站点最新列表
周大福“敬•自然”设计大赛开启
国际体验设计大会7月将在京举行
中国国防科技信息中心标志征集
云计算如何让安全问题可控
云计算是多数企业唯一拥抱互联网的机会
阿里行云
云手机年终巨献,送礼标配299起
阿里巴巴CTO王坚的"云和互联网观"
1499元买真八核 云OS双蛋大促
首届COCO桌面手机主题设计大赛
栏目最新 栏目最新列表
浅谈JavaScript编程语言的编码规范
如何在illustrator中绘制台历
Ps简单绘制一个可爱的铅笔图标
数据同步算法研究
用ps作简单的作品展示页面
CSS定位机制之一:普通流
25个最佳最闪亮的Eclipse开发项目
Illustrator中制作针线缝制文字效果
Photoshop制作印刷凹凸字体
VS2010中创建自定义SQL Rule
>> 分页 首页 前页 后页 尾页 页次:3/41个记录/页 转到 页 共4个记录

蓝色理想版权申明:除部分特别声明不要转载,或者授权我站独家播发的文章外,大家可以自由转载我站点的原创文章,但原作者和来自我站的链接必须保留(非我站原创的,按照原来自一节,自行链接)。文章版权归我站和作者共有。

转载要求:转载之图片、文件,链接请不要盗链到本站,且不准打上各自站点的水印,亦不能抹去我站点水印。

特别注意:本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有,文章若有侵犯作者版权,请与我们联系,我们将立即删除修改。

您的评论
用户名:  口令:
说明:输入正确的用户名和密码才能参与评论。如果您不是本站会员,你可以注册 为本站会员。
注意:文章中的链接、内容等需要修改的错误,请用报告错误,以利文档及时修改。
不评分 1 2 3 4 5
注意:请不要在评论中含与内容无关的广告链接,违者封ID
请您注意:
·不良评论请用报告管理员,以利管理员及时删除。
·尊重网上道德,遵守中华人民共和国的各项有关法律法规
·承担一切因您的行为而直接或间接导致的民事或刑事法律责任
·本站评论管理人员有权保留或删除其管辖评论中的任意内容
·您在本站发表的作品,本站有权在网站内转载或引用
·参与本评论即表明您已经阅读并接受上述条款
推荐文档 | 打印文档 | 评论文档 | 报告错误  
专业书推荐 更多内容
网站可用性测试及优化指南
《写给大家看的色彩书1》
《跟我去香港》
众妙之门—网站UI 设计之道
《Flex 4.0 RIA开发宝典》
《赢在设计》
犀利开发—jQuery内核详解与实践
作品集 更多内容

杂⑦杂⑧ Gold NORMANA V2