极简主义法编写JavaScript类


Posted in Javascript onNovember 02, 2017

这个所谓的"极简主义法"是荷兰程序员Gabor de Mooij提出来的,这种方法不使用this和prototype,代码部署起来非常简单,这大概也是它被叫做"极简主义法"的原因。下面就介绍如何使用极简主义法完成JavaScript的封装和继承

1. 封装

首先,它也是用一个对象模拟"类"。在这个类里面,定义一个构造函数createNew(),用来生成实例。

var Cat = {
 
createNew: function(){
 


// some code here
 

}
 };

然后,在createNew()里面,定义一个实例对象,把这个实例对象作为返回值。

var Cat = {
 
createNew: function(){
 


var cat = {};
 


cat.name = "大毛";
 


cat.makeSound = function(){ alert("喵喵喵"); };
 


return cat;
 

}
 };

使用的时候,调用createNew()方法,就可以得到实例对象。

var cat1 = Cat.createNew();
 cat1.makeSound(); // 喵喵喵

这种方法的好处是,容易理解,结构清晰优雅,符合传统的"面向对象编程"的构造,因此可以方便地部署下面的特性。

2. 继承

让一个类继承另一个类,实现起来很方便。只要在前者的createNew()方法中,调用后者的createNew()方法即可。

先定义一个Animal类:

var Animal = {
 
createNew: function(){
 


var animal = {};
 


animal.sleep = function(){ alert("睡懒觉"); };
 


return animal;
 

}
 };

然后,在Cat的createNew()方法中,调用Animal的createNew()方法

var Cat = {
 
createNew: function(){
 


var cat = Animal.createNew();
 


cat.name = "大毛";
 


cat.makeSound = function(){ alert("喵喵喵"); };
 


return cat;
 

}
 };

这样得到的Cat实例,就会继承Animal类。

var cat1 = Cat.createNew();
 cat1.sleep(); // 睡懒觉

3. 私有属性和私有方法

在createNew()方法中,只要不是定义在cat对象上的方法和属性,都是私有的。

var Cat = {
 
createNew: function(){
 


var cat = {};
 


var sound = "喵喵喵";//私有属性
 


cat.makeSound = function(){ 
      alert(sound); 
     };
 


return cat;
 

}
 };

上例的内部变量sound,外部无法读取,只有通过cat的公有方法makeSound()来读取。

var cat1 = Cat.createNew();
 alert(cat1.sound); // undefined

4. 数据共享

有时候,我们需要所有实例对象,能够读写同一项内部数据。这个时候,只要把这个内部数据,封装在类对象的里面、createNew()方法的外面即可。

var Cat = {
 
sound : "喵喵喵",
 

createNew: function(){
 


var cat = {};
 


cat.makeSound = function(){ alert(Cat.sound); };
 


cat.changeSound = function(x){ Cat.sound = x; };
 


return cat;
 

}
 };

然后,生成两个实例对象:

var cat1 = Cat.createNew();
 var cat2 = Cat.createNew();
 cat1.makeSound(); // 喵喵喵

这时,如果有一个实例对象,修改了共享的数据,另一个实例对象也会受到影响。

cat2.changeSound("啦啦啦");
 cat1.makeSound(); // 啦啦啦

 

极简主义,看起来很美好,但是也有缺点,首先是不能使用instanceof 判断对象所属的类,"cat1 instanceof Cat"无法通过,另外,极简主义虽然摆脱了使用原型链的缺点(属性不能私有、创建、继承对象不够直观),但也暴露了没用原型链的弊端:每一次生成一个实例,都必须为重复的内容,多占用一些内存。

总结

以上所述是小编给大家介绍的极简主义法编写JavaScript类,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
Mootools 1.2教程 滚动条(Slider)
Sep 15 Javascript
jQuery文本框(input textare)事件绑定方法教程
Apr 24 Javascript
jQuery Ajax()方法使用指南
Nov 19 Javascript
jQuery获取元素父节点的方法
Jun 21 Javascript
微信小程序-拍照或选择图片并上传文件
Jan 06 Javascript
Javascript中for循环语句的几种写法总结对比
Jan 23 Javascript
浅谈Node Inspector 代理实现
Oct 19 Javascript
JsChart组件使用详解
Mar 04 Javascript
js将键值对字符串转为json字符串的方法
Mar 30 Javascript
React中使用UMEditor的方法示例
Dec 27 Javascript
vue实践---vue不依赖外部资源实现简单多语操作
Sep 21 Javascript
antd table按表格里的日期去排序操作
Nov 17 Javascript
利用nvm管理多个版本的node.js与npm详解
Nov 02 #Javascript
JavaScript屏蔽Backspace键的实现代码
Nov 02 #Javascript
Vue源码学习之初始化模块init.js解析
Nov 02 #Javascript
为输入框加入数字js校验代码分享
Nov 02 #Javascript
详谈js中标准for循环与foreach(for in)的区别
Nov 02 #Javascript
使用 Node.js 模拟滑动拼图验证码操作的示例代码
Nov 02 #Javascript
基于JavaScript+HTML5 实现打地鼠小游戏逻辑流程图文详解(附完整代码)
Nov 02 #Javascript
You might like
php下通过curl抓取yahoo boss 搜索结果的实现代码
2011/06/10 PHP
PHP常用设计模式之委托设计模式
2016/02/13 PHP
Ubuntu server 11.04安装memcache及php使用memcache来存储session的方法
2016/05/31 PHP
PHP常见加密函数用法示例【crypt与md5】
2019/01/27 PHP
Yii框架的路由配置方法分析
2019/09/09 PHP
Javascript的一种模块模式
2010/09/08 Javascript
javascript针对DOM的应用分析(二)
2012/04/15 Javascript
js日期相关函数总结分享
2013/10/15 Javascript
Javascrip实现文字跳动特效
2016/11/27 Javascript
js实现拖拽功能
2017/03/01 Javascript
简单实现jQuery弹窗效果
2017/10/30 jQuery
Node.js文件编码格式的转换的方法
2018/04/27 Javascript
vue裁切预览组件功能的实现步骤
2018/05/04 Javascript
小程序实现左右来回滚动字幕效果
2018/12/28 Javascript
详解使用React.memo()来优化函数组件的性能
2019/03/19 Javascript
JavaScript实现选项卡效果的分析及步骤
2019/04/16 Javascript
Vue源码探究之虚拟节点的实现
2019/04/17 Javascript
vue.js实现回到顶部动画效果
2019/07/31 Javascript
layui 数据表格 点击分页按钮 监听事件的实例
2019/09/02 Javascript
js canvas实现星空连线背景特效
2019/11/01 Javascript
VUE UPLOAD 通过ACTION返回上传结果操作
2020/09/07 Javascript
Vue基本指令实例图文讲解
2021/02/25 Vue.js
[59:30]VG vs LGD 2019国际邀请赛淘汰赛 胜者组 BO3 第二场 8.22
2019/09/05 DOTA
详解Golang 与python中的字符串反转
2017/07/21 Python
Python利用ElementTree模块处理XML的方法详解
2017/08/31 Python
Python lambda函数基本用法实例分析
2018/03/16 Python
tensorflow 中对数组元素的操作方法
2018/07/27 Python
python在回调函数中获取返回值的方法
2019/02/22 Python
Python 转换RGB颜色值的示例代码
2019/10/13 Python
Python通过递归获取目录下指定文件代码实例
2019/11/07 Python
python使用pymongo与MongoDB基本交互操作示例
2020/04/09 Python
PHP数据运算类型都有哪些
2013/11/05 面试题
内业资料员岗位职责
2014/01/04 职场文书
给老婆的婚前保证书
2014/02/01 职场文书
英文感谢信格式
2015/01/21 职场文书
关于antd tree 和父子组件之间的传值问题(react 总结)
2021/06/02 Javascript