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+ajax 购物车框架(入门篇)
Oct 29 Javascript
javascript:json数据的页面绑定示例代码
Jan 26 Javascript
JavaScript实现同步于本地时间的动态时间显示方法
Feb 02 Javascript
JavaScript中的方法重载实例
Mar 16 Javascript
JS实现slide文字框缩放伸展效果代码
Nov 05 Javascript
jquery编写Tab选项卡滚动导航切换特效
Jul 17 Javascript
JQuery 设置checkbox值二次无效的解决方法
Jul 22 Javascript
微信小程序中使元素占满整个屏幕高度实现方法
Dec 14 Javascript
前端axios下载excel文件(二进制)的处理方法
Jul 31 Javascript
小程序自定义日历效果
Dec 29 Javascript
简单了解JavaScript arguement原理及作用
May 28 Javascript
js 图片懒加载的实现
Oct 21 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
在PHP3中实现SESSION的功能(三)
2006/10/09 PHP
PHP通用检测函数集合
2006/11/25 PHP
php设计模式之观察者模式的应用详解
2013/05/21 PHP
php获取字段名示例分享
2014/03/03 PHP
Joomla简单判断用户是否登录的方法
2016/05/04 PHP
详解laravel安装使用Passport(Api认证)
2018/07/27 PHP
JavaScript中的Screen屏幕对象
2008/01/16 Javascript
基于jquery的下拉框改变动态添加和删除表格实现代码
2020/09/12 Javascript
onkeypress字符按键兼容所有浏览器使用介绍
2013/04/24 Javascript
jQuery焦点图切换简易插件制作过程全纪录
2014/08/27 Javascript
js实现下拉框选择要显示图片的方法
2015/02/16 Javascript
javascript实现图片延迟加载方法汇总(三种方法)
2015/08/27 Javascript
javascript实现tab切换的四种方法
2015/11/05 Javascript
js实现的简练高效拖拽功能示例
2016/12/21 Javascript
iscroll.js滚动加载实例详解
2017/07/18 Javascript
初探JavaScript 面向对象(推荐)
2017/09/03 Javascript
vue实现员工信息录入功能
2020/06/11 Javascript
vue+Element-ui实现登录注册表单
2020/11/17 Javascript
python中的函数用法入门教程
2014/09/02 Python
浅谈五大Python Web框架
2017/03/20 Python
TensorFlow安装及jupyter notebook配置方法
2017/09/08 Python
详解Python nose单元测试框架的安装与使用
2017/12/20 Python
Python中getpass模块无回显输入源码解析
2018/01/11 Python
Python 查看文件的读写权限方法
2018/01/23 Python
Python实现的井字棋(Tic Tac Toe)游戏示例
2018/01/31 Python
tensorflow 恢复指定层与不同层指定不同学习率的方法
2018/07/26 Python
pandas删除指定行详解
2019/04/04 Python
python之pyqt5通过按钮改变Label的背景颜色方法
2019/06/13 Python
日本最大的眼镜购物网站:Oh My Glasses
2016/11/13 全球购物
澳大利亚领先的美容护肤品零售商之一:SkincareStore
2018/01/22 全球购物
Bose美国官网:购买Bose耳机和音箱
2019/03/10 全球购物
营业经理岗位职责
2013/11/10 职场文书
咖啡店的创业计划书,让你hold不住
2014/01/03 职场文书
关于保护环境的建议书
2014/05/13 职场文书
2015年派出所工作总结
2015/04/24 职场文书
JavaScript数组 几个常用方法总结
2021/11/11 Javascript