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 相关文章推荐
在js文件中如何获取basePath处理js路径问题
Jul 10 Javascript
html页面显示年月日时分秒和星期几的两种方式
Aug 20 Javascript
Jquery实现自定义tooltip示例代码
Feb 12 Javascript
js中直接声明一个对象的方法
Aug 10 Javascript
JS实现的用来对比两个用指定分隔符分割的字符串是否相同
Sep 19 Javascript
node.js中的path.basename方法使用说明
Dec 09 Javascript
jquery图片切换插件
Mar 16 Javascript
jQuery插件windowScroll实现单屏滚动特效
Jul 14 Javascript
JS原型对象的创建方法详解
Jun 16 Javascript
JS简单获取当前年月日星期的方法示例
Feb 07 Javascript
js使用文档就绪函数动态改变页面内容示例【innerHTML、innerText】
Nov 07 Javascript
vue setInterval 定时器失效的解决方式
Jul 30 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大批量数据操作时临时调整内存与执行时间的方法
2011/04/20 PHP
MongoDB在PHP中的常用操作小结
2014/02/20 PHP
Zend Framework教程之视图组件Zend_View用法详解
2016/03/05 PHP
thinkPHP3.2简单实现文件上传的方法
2016/05/16 PHP
比较完整的微信开发php代码
2016/08/02 PHP
用javascript实现的图片马赛克后显示并切换加文字功能
2007/04/21 Javascript
jquery多浏览器捕捉回车事件代码
2010/06/22 Javascript
jquery对表单操作2
2011/04/06 Javascript
百度地图api应用标注地理位置信息(js版)
2013/02/01 Javascript
JavaScript控制各种浏览器全屏模式的方法、属性和事件介绍
2014/04/03 Javascript
浅谈Jquery为元素绑定事件
2015/04/27 Javascript
基于Jquery和html5实现炫酷的3D焦点图动画
2016/03/02 Javascript
实践中学习AngularJS表单
2016/03/21 Javascript
javascript类型系统——undefined和null全面了解
2016/07/13 Javascript
浅谈JS使用[ ]来访问对象属性
2016/09/21 Javascript
Node.js+ES6+dropload.js实现移动端下拉加载实例
2017/06/01 Javascript
原生JS检测CSS3动画是否结束的方法详解
2019/01/27 Javascript
简单了解vue.js数组的常用操作
2019/06/17 Javascript
[54:45]2018DOTA2亚洲邀请赛 4.1 小组赛 A组 Optic vs OG
2018/04/02 DOTA
Python之文字转图片方法
2018/05/10 Python
Python使用Selenium模块模拟浏览器抓取斗鱼直播间信息示例
2018/07/18 Python
Python爬取个人微信朋友信息操作示例
2018/08/03 Python
PyCharm设置护眼背景色的方法
2018/10/29 Python
Python3环境安装Scrapy爬虫框架过程及常见错误
2019/07/12 Python
TFRecord文件查看包含的所有Features代码
2020/02/17 Python
pandas数据处理之绘图的实现
2020/06/15 Python
使用python编写一个语音朗读闹钟功能的示例代码
2020/07/14 Python
css3利用transform变形结合事件完成扇形导航
2020/10/26 HTML / CSS
应用化学专业本科生求职信
2013/09/29 职场文书
企业项目策划书
2014/01/11 职场文书
党员干部2014全国两会学习心得体会
2014/03/10 职场文书
领导干部廉政承诺书
2014/03/27 职场文书
共产党员公开承诺书范文
2014/03/28 职场文书
会计求职自荐信
2014/06/20 职场文书
社区端午节活动总结
2015/02/11 职场文书
忆童年!用Python实现愤怒的小鸟游戏
2021/06/07 Python