极简主义法编写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 相关文章推荐
Javascript 跨域访问解决方案
Feb 14 Javascript
使用js获取QueryString的方法小结
Feb 28 Javascript
基于jquery自定义图片热区效果
Jul 21 Javascript
Express.JS使用详解
Jul 17 Javascript
js中键盘事件实例简析
Jan 10 Javascript
理解javascript中的MVC模式
Jan 28 Javascript
javascript学习笔记_浅谈基础语法,类型,变量
Sep 19 Javascript
JavaScript获取URL中参数querystring的方法详解
Oct 11 Javascript
Angularjs 实现动态添加控件功能
May 25 Javascript
微信小程序调用PHP后台接口 解析纯html文本
Jun 13 Javascript
Vue如何获取数据列表展示
Dec 11 Javascript
Postman无法正常返回结果问题解决
Aug 28 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
Flash空降上海 化身大魔王接受挑战
2020/03/02 星际争霸
php+AJAX传送中文会导致乱码的问题的解决方法
2008/09/08 PHP
使用php 获取时间今天明天昨天时间戳的详解
2013/06/20 PHP
推荐十款免费 WordPress 插件
2015/03/24 PHP
PHP实现支付宝即时到账功能
2016/12/21 PHP
php正则判断是否为合法身份证号的方法
2017/03/16 PHP
ThinkPHP防止重复提交表单的方法实例分析
2018/05/10 PHP
Laravel框架基于ajax实现二级联动功能示例
2019/01/17 PHP
json 实例详细说明教程
2009/10/31 Javascript
js实现的真正的iframe高度自适应(兼容IE,FF,Opera)
2010/03/07 Javascript
js获取某月的最后一天日期的简单实例
2013/06/22 Javascript
Jquery easyUI 更新行示例
2014/03/06 Javascript
JavaScript监听和禁用浏览器回车事件实例
2015/01/31 Javascript
jQuery层动画定位滑动效果的方法
2015/04/30 Javascript
jquery+CSS3模拟Path2.0动画菜单效果代码
2015/08/31 Javascript
JQuery validate插件验证用户注册信息
2016/05/11 Javascript
浅谈jQuery 中的事件冒泡和阻止默认行为
2016/05/28 Javascript
AngularJS入门教程之控制器详解
2016/07/27 Javascript
BootStrap Datepicker 插件修改为默认中文的实现方法
2017/02/10 Javascript
微信小程序自定义prompt组件步骤详解
2018/06/12 Javascript
详解Nuxt.js 实战集锦
2019/11/19 Javascript
跟老齐学Python之大话题小函数(2)
2014/10/10 Python
Django中实现点击图片链接强制直接下载的方法
2015/05/14 Python
python学习笔记之调用eval函数出现invalid syntax错误问题
2015/10/18 Python
Python使用logging模块实现打印log到指定文件的方法
2018/09/05 Python
python中shell执行知识点
2020/05/06 Python
PySide2出现“ImportError: DLL load failed: 找不到指定的模块”的问题及解决方法
2020/06/10 Python
python基于exchange函数发送邮件过程详解
2020/11/06 Python
百联网上商城:i百联
2017/01/28 全球购物
医学生职业规划范文
2014/01/05 职场文书
生物工程专业求职信
2014/09/03 职场文书
学校运动会广播稿100条
2014/09/14 职场文书
党的群众路线教育实践活动领导班子整改措施
2014/09/30 职场文书
2016大学优秀学生干部事迹材料
2016/03/01 职场文书
2016年安康杯竞赛活动总结
2016/04/05 职场文书
python机器学习Github已达8.9Kstars模型解释器LIME
2021/11/23 Python