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 innerHTML 的一些问题的解决方法
Jun 22 Javascript
基于jQuery的history历史记录插件
Dec 11 Javascript
JQuery教学之性能优化
May 14 Javascript
自定义jquery模态窗口插件无法在顶层窗口显示问题
May 29 Javascript
JQuery删除DOM节点的方法
Jun 11 Javascript
js实现二级菜单渐隐显示
Nov 03 Javascript
Bootstrap每天必学之标签页(Tab)插件
Aug 09 Javascript
你不需要jQuery(三) 新AJAX方法fetch()
Jun 14 Javascript
利用Angularjs和原生JS分别实现动态效果的输入框
Sep 01 Javascript
详解angularjs利用ui-route异步加载组件
May 21 Javascript
elementui的el-popover修改样式不生效的解决
Jun 30 Javascript
JS数组方法some、every和find的使用详情
Oct 05 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读取30天之内的根据算法排序的代码
2008/04/06 PHP
php 操作符与控制结构
2012/03/07 PHP
php递归遍历多维数组的方法
2015/04/18 PHP
PHP编写文件多服务器同步程序
2016/07/02 PHP
thinkphp3.2.3 分页代码分享
2016/07/28 PHP
PHP实现的文件浏览器功能简单示例
2019/09/12 PHP
详细分析PHP 命名空间(namespace)
2020/06/30 PHP
EXT窗口Window及对话框MessageBox
2011/01/27 Javascript
js下获得客户端操作系统的函数代码(1:vista,2:windows7,3:2000,4:xp,5:2003,6:2008)
2011/10/31 Javascript
详解JavaScript基于面向对象之创建对象(1)
2015/12/10 Javascript
简单总结JavaScript中的String字符串类型
2016/05/26 Javascript
JSON格式的时间/Date(2367828670431)/格式转为正常的年-月-日 格式的代码
2016/07/27 Javascript
JS实现浏览器打印、打印预览示例
2017/02/28 Javascript
详解webpack2+React 实例demo
2017/09/11 Javascript
jquery之基本选择器practice(实例讲解)
2017/09/30 jQuery
详解javascript中的变量提升和函数提升
2018/05/24 Javascript
Vue press 支持图片放大功能的实例代码
2018/11/09 Javascript
js指定日期增加指定月份的实现方法
2018/12/19 Javascript
js实现图片粘贴到网页
2019/12/06 Javascript
Angular6项目打包优化的实现方法
2019/12/15 Javascript
JS使用setInterval计时器实现挑战10秒
2020/11/08 Javascript
[55:03]完美世界DOTA2联赛PWL S2 LBZS vs FTD.C 第二场 11.20
2020/11/20 DOTA
python获取糗百图片代码实例
2013/12/18 Python
python寻找list中最大值、最小值并返回其所在位置的方法
2018/06/27 Python
django+echart绘制曲线图的方法示例
2018/11/26 Python
python 制作网站筛选工具(附源码)
2021/01/21 Python
银行实习自我鉴定
2013/10/12 职场文书
计算机本科生自荐信
2013/10/15 职场文书
车间工艺员岗位职责
2013/12/09 职场文书
五一手机促销方案
2014/03/08 职场文书
项目施工员岗位职责
2014/03/09 职场文书
经销商订货会主持词
2014/03/27 职场文书
党员年终个人总结
2015/02/14 职场文书
创业计划书之健康营养产业
2019/10/15 职场文书
关于React Native使用axios进行网络请求的方法
2021/08/02 Javascript
手写Spirit防抖函数underscore和节流函数lodash
2022/03/22 Javascript