Javascript学习笔记9 prototype封装继承


Posted in Javascript onJanuary 11, 2010

好,那就让我们一步步打造,首先让我们来看下继承原本的写法:

<script> 
var Person = function(name, age) { 
this.name = name; 
this.age = age; 
} 
Person.prototype.SayHello = function () { 
alert(this.name + "," + this.age); 
}; 
var Programmer = function (name, age, salary) { 
Person.call(this, name, age); 
this.salary = salary; 
}; 
Programmer.prototype = new Person(); 
var pro = new Programmer("kym", 21, 500); 
pro.SayHello(); 
</script>

我们看到,在实际上,继承的根本就在于这一步Programmer.prototype=new Person()。也就是说把Person加到原型链上。这一点在Javascript学习笔记7——原型链的原理 已经有过比较详尽的解释。
那也就是说,我们实现的关键就在于原型链的打造。
在上文中,我们用JSON来打造了一个原型,其原型链是p.__proto__=Person。那么我们希望在这个上封装继承,那么原型链应该是p.__proto__.__proto__=SuperClass,也就是说Person.__proto__=SuperClass。但是按照我们上面代码的继承方法,原型链关系是Person.__proto__=SuperClass.prototype。
这个和我们在上文中一样,我们的办法就是借助一个辅助函数,将原来的函数内的属性赋给X,然后令X.prototype=SuperClass即可,也就是说我们将子原型进行一个封装。
好,就按照这个思路,我们来实现利用原型链的继承关系的封装。
<script> 
var Factory = { 
Create: function (className, params) { 
var temp = function () { 
className.Create.apply(this, params); 
}; 
temp.prototype = className; 
var result = new temp(); 
return result; 
}, 
CreateBaseClass: function (baseClass, subClass) { 
var temp = function () { 
for (var member in subClass) { 
this[member] = subClass[member]; 
} 
}; 
temp.prototype = baseClass; 
return new temp(); 
} 
}; 
var People = { 
Create: function (name, age) { 
this.name = name; 
this.age = age; 
}, 
SayHello: function () { 
alert("Hello,My name is " + this.name + ".I am " + this.age); 
} 
}; 
var Temp = { 
Create: function (name, age, salary) { 
People.Create.call(this, name, age); 
this.salary = salary; 
}, 
Introduce: function () { 
alert(this.name + "$" + this.age + "$" + this.salary); 
} 
}; 
var Programmer = Factory.CreateBaseClass(People, Temp); 
var pro = Factory.Create(Programmer, ["kym", 21, 500]); 
pro.SayHello(); 
</script>

这样就完成了我们对继承关系的封装。当然,我们也可以不单独写一个变量:
var Programmer = Factory.CreateBaseClass(People, 
{ 
Create: function (name, age, salary) { 
People.Create.call(this, name, age); 
this.salary = salary; 
}, 
Introduce: function () { 
alert(this.name + "$" + this.age + "$" + this.salary); 
} 
});

当然,这全凭个人爱好了,个人认为第一种办法相对更清晰一些,但是第二种办法则更优雅。
Javascript 相关文章推荐
js以对象为索引的关联数组
Jul 04 Javascript
jQuery EasyUI API 中文文档 - Spinner微调器使用
Oct 21 Javascript
javascript打印输出json实例
Nov 11 Javascript
jQuery实现异步获取json数据的2种方式
Aug 29 Javascript
DOM基础教程之使用DOM设置文本框
Jan 20 Javascript
bootstrap table复杂操作代码
Nov 01 Javascript
jQuery中Datatables增加跳转到指定页功能
Feb 08 Javascript
jquery实现图片放大点击切换
Jun 06 jQuery
详解react如何在组件中获取路由参数
Jun 15 Javascript
vue中$set的使用(结合在实际应用中遇到的坑)
Jul 10 Javascript
node+express框架中连接使用mysql(经验总结)
Nov 10 Javascript
原生js实现随机点餐效果
Dec 10 Javascript
Javascript学习笔记8 用JSON做原型
Jan 11 #Javascript
Javascript学习笔记7 原型链的原理
Jan 11 #Javascript
Javascript学习笔记6 prototype的提出
Jan 11 #Javascript
Javascript学习笔记5 类和对象
Jan 11 #Javascript
Javascript学习笔记4 Eval函数
Jan 11 #Javascript
Javascript学习笔记2 函数
Jan 11 #Javascript
Javascript学习笔记1 数据类型
Jan 11 #Javascript
You might like
深入密码加salt原理的分析
2013/06/06 PHP
php实现生成验证码实例分享
2016/04/10 PHP
thinkphp3.x中session方法的用法分析
2016/05/20 PHP
Linux下源码包安装Swoole及基本使用操作图文详解
2019/04/02 PHP
docker-compose部署php项目实例详解
2019/07/30 PHP
宝塔面板在NGINX环境中TP5.1如何运行?
2021/03/09 PHP
线路分流自动跳转代码;希望对大家有用!
2006/12/02 Javascript
基于jquery实现状态限定编辑的代码
2012/02/11 Javascript
jQuery控制cookie过期时间的方法
2015/04/07 Javascript
javascript引用类型指针的工作方式
2015/04/13 Javascript
基于Vue实现timepicker
2017/04/25 Javascript
浅谈关于angularJs中使用$.ajax的注意点
2017/08/12 Javascript
nodejs中Express与Koa2对比分析
2018/02/06 NodeJs
微信小程序实现团购或秒杀批量倒计时
2020/11/01 Javascript
JavaScript键盘事件响应顺序详解
2019/09/30 Javascript
vue2.0实现列表数据增加和删除
2020/06/17 Javascript
[03:17]2014DOTA2 国际邀请赛中国区预选赛 四强专访
2014/05/23 DOTA
[01:08:29]DOTA2-DPC中国联赛定级赛 RNG vs Aster BO3第一场 1月9日
2021/03/11 DOTA
python中pycurl库的用法实例
2014/09/30 Python
Python实现telnet服务器的方法
2015/07/10 Python
Python对数据库操作
2016/03/28 Python
Linux中安装Python的交互式解释器IPython的教程
2016/06/13 Python
在Python中实现替换字符串中的子串的示例
2018/10/31 Python
Python中的单下划线和双下划线使用场景详解
2019/09/09 Python
Python3实现个位数字和十位数字对调, 其乘积不变
2020/05/03 Python
手把手教你用Django执行原生SQL的方法
2021/02/18 Python
美国领先的宠物用品和宠物食品零售商:Petco
2020/10/28 全球购物
杭州-DOTNET笔试题集
2013/09/25 面试题
北京天润融通.net面试题笔试题
2012/02/20 面试题
期末自我鉴定
2014/02/02 职场文书
《浅水洼里的小鱼》听课反思
2014/02/28 职场文书
会计工作决心书
2014/03/11 职场文书
家长通知书家长意见
2015/06/03 职场文书
学前教育见习总结
2015/06/23 职场文书
Java 写一个简单的图书管理系统
2022/04/26 Java/Android
关于Redis的主从复制及哨兵问题
2022/06/16 Redis