JS 的应用开发初探(mootools)


Posted in Javascript onDecember 19, 2009

做了三个小demo,本来想做一个类似Gmail的界面出来后来突然发现机器上没有Office,就干脆做了一个类PPT演示的小玩意。

基于js的应用开发总结起来主要有如下几点:

封装粒度
常用功能封装为可重复使用的组件,需要合理选择组件封装粒度,粒度过大不便于复用,粒度过小则得不偿失。

代码结构规划
吸收传统软件开发的思想将代码按功能划分为不同的区块:初始化,事件绑定,事件逻辑处理,外部Callback调用

Js的面向对象
简单起见可以使用构造函数(其实就是普通的Function)+ prototype定义,虽然看起来不是很优雅不过却是比较直接的解决办法。演示代码中使用了Mootools类库,相比jQuery来说,这个类库的面向对象特性使用起来个人感觉更好一些,当然也可以使用它自带的Class申明方式来编写你自己的Class:

Meta.Controls.Pager = new Class({ 
Implements: [Events, Options], 
options: { 
pageIndex :1, // 当前页码, 从1开始 
size : 10, // 每页显示记录数 
maxButtons : 5,// 显示的分页按钮数量 
showPageSize:true, // 显示分页大小选项. 
sizeArray:[10, 25] 
}, 
initialize: function (A) { 
this.setOptions(A); 
this.pageIndex = this.options.pageIndex; 
this.size = this.options.size; 
this.maxButtons = this.options.maxButtons; 
this.itemCount = 0; 
this.pageCount =0 ; 
}, 
...... 
}

这样的方式也是不错的选择,代码逻辑结构清晰一目了然。

单元测试
通常认为浏览器上的js 应用要做单元测试不好做,原因主要是跟DOM关系太紧密,但也不是完全没有办法,比如Google的Closure就做得不错,使用Mock的对象来模拟Dom元素并解耦代码逻辑与Dom对象操作。
下面是本次实例的代码,感兴趣的童鞋自行下载。

Javascript 相关文章推荐
Javascript 面向对象编程(coolshell)
Mar 18 Javascript
js解析与序列化json数据(二)序列化探讨
Feb 01 Javascript
js内存泄露的几种情况详细探讨
May 31 Javascript
JavaScript中this详解
Sep 01 Javascript
js重写方法的简单实现
Jul 10 Javascript
搭建Bootstrap离线文档的方法
Dec 02 Javascript
JS简单判断函数是否存在的方法
Feb 13 Javascript
Ajax实现不刷新取最新商品
Mar 01 Javascript
将jquery.qqFace.js表情转换成微信的字符码
Dec 01 jQuery
JS实现左边列表移到到右边列表功能
Mar 28 Javascript
vue项目中vue-i18n和element-ui国际化开发实现过程
Apr 25 Javascript
解决pycharm双击但是无法打开的情况
Oct 31 Javascript
用js实现层随着内容大小动态渐变改变 推荐
Dec 19 #Javascript
javascript demo 基本技巧
Dec 18 #Javascript
IE和Firefox下event事件杂谈
Dec 18 #Javascript
替代window.event.srcElement效果的可兼容性的函数
Dec 18 #Javascript
JavaScript 序列化对象实现代码
Dec 18 #Javascript
让div层随鼠标移动的实现代码 ie ff
Dec 18 #Javascript
Javascript在IE或Firefox下获取鼠标位置的代码
Dec 18 #Javascript
You might like
PHP脚本的10个技巧(1)
2006/10/09 PHP
一个PHP日历程序
2006/12/06 PHP
php设计模式 Adapter(适配器模式)
2011/06/26 PHP
浅析ThinkPHP缓存之快速缓存(F方法)和动态缓存(S方法)(日常整理)
2015/10/26 PHP
Save a File Using a File Save Dialog Box
2007/06/18 Javascript
可以显示单图片,多图片ajax请求的ThickBox3.1类下载
2007/12/23 Javascript
IE8的JavaScript点击事件(onclick)不兼容的解决方法
2013/11/22 Javascript
nodeJS代码实现计算交社保是否合适
2015/03/09 NodeJs
jquery+html5制作超酷的圆盘时钟表
2015/04/14 Javascript
jQuery鼠标事件汇总
2015/08/30 Javascript
浅析Node.js 中 Stream API 的使用
2015/10/23 Javascript
利用jQuery对无序列表排序的简单方法
2016/10/16 Javascript
Angular表单验证实例详解
2016/10/20 Javascript
JavaScript+CSS相册特效实例代码
2017/09/07 Javascript
vue双向数据绑定知识点总结
2018/04/18 Javascript
JavaScript展开操作符(Spread operator)详解
2019/07/20 Javascript
通过实例解析vuejs如何实现调试代码
2020/07/16 Javascript
Python中文字符串截取问题
2015/06/15 Python
python回调函数中使用多线程的方法
2017/12/25 Python
Python中支持向量机SVM的使用方法详解
2017/12/26 Python
pycharm: 恢复(reset) 误删文件的方法
2018/10/22 Python
python+unittest+requests实现接口自动化的方法
2018/11/29 Python
PyQt 图解Qt Designer工具的使用方法
2019/08/06 Python
关于python的缩进规则的知识点详解
2020/06/22 Python
calendar在python3时间中常用函数举例详解
2020/11/18 Python
关于box-sizing的全面理解
2016/07/28 HTML / CSS
匡威爱尔兰官网:Converse爱尔兰
2019/06/09 全球购物
俄罗斯三星品牌商店:GalaxyStore
2020/11/04 全球购物
what is the difference between ext2 and ext3
2013/11/03 面试题
学校联谊活动方案
2014/02/15 职场文书
应届生求职信
2014/05/31 职场文书
村长党的群众路线教育实践活动个人对照检查材料
2014/09/23 职场文书
2015年采购部工作总结
2015/04/23 职场文书
python munch库的使用解析
2021/05/25 Python
为什么MySQL不建议使用SELECT *
2022/04/03 MySQL
SQL Server删除表中的重复数据
2022/05/25 SQL Server