极简主义法编写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 相关文章推荐
IE与FireFox的兼容性问题分析
Apr 22 Javascript
锋利的jQuery 要点归纳(二) jQuery中的DOM操作(下)
Mar 23 Javascript
基于jQuery的仿flash的广告轮播代码
Nov 04 Javascript
Node.js编码规范
Jul 14 Javascript
jQuery中:submit选择器用法实例
Jan 03 Javascript
C++中的string类的用法小结
Aug 07 Javascript
使用jQuery中的wrap()函数操作HTML元素的教程
May 24 Javascript
angularjs实现文字上下无缝滚动特效代码
Sep 04 Javascript
bootstrap实现每隔5秒自动轮播效果
Dec 20 Javascript
BootStrap3使用错误记录及解决办法
Dec 22 Javascript
webpack vue项目开发环境局域网访问方法
Mar 20 Javascript
maptalks+three.js+vue webpack实现二维地图上贴三维模型操作
Aug 10 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
PHP5+UTF8多文件上传类
2008/10/17 PHP
一些需要禁用的PHP危险函数(disable_functions)
2012/02/23 PHP
PHP切割整数工具类似微信红包金额分配的思路详解
2019/09/18 PHP
thinkphp5.1 框架导入/导出excel文件操作示例
2020/05/25 PHP
js的flv视频播放器插件使用方法
2015/06/23 Javascript
JavaScript SHA512加密算法详细代码
2016/10/06 Javascript
JS实现用户注册时获取短信验证码和倒计时功能
2016/10/27 Javascript
nodejs中sleep功能实现暂停几秒的方法
2017/07/12 NodeJs
jQuery选择器之子元素选择器详解
2017/09/18 jQuery
Node.js学习之地址解析模块URL的使用详解
2017/09/28 Javascript
JS+CSS实现滚动数字时钟效果
2017/12/25 Javascript
Element-UI中Upload上传文件前端缓存处理示例
2019/02/21 Javascript
JS数组中对象去重操作示例
2019/06/04 Javascript
使用react context 实现vue插槽slot功能
2019/07/18 Javascript
leaflet加载geojson叠加显示功能代码
2020/02/21 Javascript
jquery实现轮播图特效
2020/04/12 jQuery
vue使用screenfull插件实现全屏功能
2020/09/17 Javascript
浅析Python中return和finally共同挖的坑
2017/08/18 Python
python实现协同过滤推荐算法完整代码示例
2017/12/15 Python
使用python 3实现发送邮件功能
2018/06/15 Python
如何优雅地处理Django中的favicon.ico图标详解
2018/07/05 Python
python实战教程之自动扫雷
2018/07/13 Python
python实现朴素贝叶斯算法
2018/11/19 Python
Python基础教程之异常详解
2019/01/10 Python
基于keras输出中间层结果的2种实现方式
2020/01/24 Python
python爬虫筛选工作实例讲解
2020/11/23 Python
美国指甲油品牌:Deco Miami
2017/01/30 全球购物
介绍一下SQL中union,intersect和minus
2012/04/05 面试题
巡警年度自我鉴定
2014/02/21 职场文书
党员四风剖析材料
2014/08/27 职场文书
房屋转让协议书
2014/10/18 职场文书
群众路线教育实践活动整改落实情况汇报
2014/10/28 职场文书
人事局接收函
2015/01/30 职场文书
尼克胡哲观后感
2015/06/08 职场文书
JS数组方法some、every和find的使用详情
2021/10/05 Javascript
MySQL为数据表建立索引的原则详解
2022/03/03 MySQL