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 相关文章推荐
原创javascript小游戏实现代码
Aug 19 Javascript
javascript学习之闭包分析
Dec 02 Javascript
jquery实现人性化的有选择性禁用鼠标右键
Jun 30 Javascript
jQuery实现仿QQ头像闪烁效果的文字闪动提示代码
Nov 03 Javascript
javascript基于原型链的继承及call和apply函数用法分析
Dec 15 Javascript
Vue声明式渲染详解
May 17 Javascript
JS实现微信摇一摇原理解析
Jul 22 Javascript
通过vue-cli3构建一个SSR应用程序的方法
Sep 13 Javascript
Vue监听一个数组id是否与另一个数组id相同的方法
Sep 26 Javascript
简单了解vue中的v-if和v-show的区别
Oct 08 Javascript
mpvue 项目初始化及实现授权登录的实现方法
Jul 20 Javascript
原生js滑动轮播封装
Jul 31 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
全国FM电台频率大全 - 5 内蒙古自治区
2020/03/11 无线电
PHP:风雨欲来 路在何方?
2006/10/09 PHP
PHP快速按行读取CSV大文件的封装类分享(也适用于其它超大文本文件)
2014/04/10 PHP
PHP递归复制、移动目录的自定义函数分享
2014/11/18 PHP
PHP使用PHPexcel导入导出数据的方法
2015/11/14 PHP
php实现的debug log日志操作类实例
2016/07/12 PHP
Jquery 的outerHeight方法使用介绍
2013/09/11 Javascript
js简单实现删除记录时的提示效果
2013/12/05 Javascript
js实现的类似于asp数据字典的数据类型代码实例
2014/09/03 Javascript
JavaScript实现点击按钮切换网页背景色的方法
2015/10/17 Javascript
Fullpage.js固定导航栏-实现定位导航栏
2016/03/17 Javascript
js微信分享API
2020/10/11 Javascript
jQuery 移动端拖拽(模块化开发,触摸事件,webpack)
2016/10/28 Javascript
html判断当前页面是否在iframe中的实例
2016/11/30 Javascript
jquery拖动改变div大小
2017/07/04 jQuery
js 概率计算(简单版)
2017/09/12 Javascript
Vue封装一个简单轻量的上传文件组件的示例
2018/03/21 Javascript
Angular6 正则表达式允许输入部分中文字符
2018/09/10 Javascript
vue封装可复用组件confirm,并绑定在vue原型上的示例
2019/10/31 Javascript
在vue中使用jsonp进行跨域请求接口操作
2020/10/29 Javascript
详解如何在vue+element-ui的项目中封装dialog组件
2020/12/11 Vue.js
[01:04]DOTA2上海特锦赛现场采访 FreeAgain遭众解说围攻
2016/03/25 DOTA
[38:27]完美世界DOTA2联赛PWL S2 Forest vs FTD.C 第二场 11.26
2020/11/30 DOTA
[42:00]完美世界DOTA2联赛PWL S3 Phoenix vs INK ICE 第一场 12.13
2020/12/17 DOTA
python3.X 抓取火车票信息【修正版】
2018/06/19 Python
Python绘制股票移动均线的实例
2019/08/24 Python
pytorch dataloader 取batch_size时候出现bug的解决方式
2020/02/20 Python
10个python3常用排序算法详细说明与实例(快速排序,冒泡排序,桶排序,基数排序,堆排序,希尔排序,归并排序,计数排序)
2020/03/17 Python
Python如何读写二进制数组数据
2020/08/01 Python
django 获取字段最大值,最新的记录操作
2020/08/09 Python
利用Python批量识别电子账单数据的方法
2021/02/08 Python
WEB控件及HTML服务端控件能否调用客户端方法?如果能,请解释如何调用?
2015/08/25 面试题
教育课题研究自我鉴定范文
2013/12/28 职场文书
五星级酒店餐饮部总监的标准岗位职责
2014/02/17 职场文书
中秋联欢会主持词
2015/07/04 职场文书
在HTML中引入CSS的几种方式介绍
2021/12/06 HTML / CSS