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 相关文章推荐
通过隐藏option实现select的联动效果
Nov 10 Javascript
JS完成代码前最好对其做5件事
Apr 07 Javascript
jQuery插件scroll实现无缝滚动效果
Apr 27 Javascript
jquery插件uploadify实现带进度条的文件批量上传
Dec 13 Javascript
javascript事件处理模型实例说明
May 31 Javascript
纯js和css完成贪吃蛇小游戏demo
Sep 01 Javascript
Bootstrap基本样式学习笔记之标签(5)
Dec 07 Javascript
详解用vue编写弹出框组件
Jul 04 Javascript
详解Vue.js自定义tipOnce指令用法实例
Dec 19 Javascript
jQuery实现的网站banner图片无缝轮播效果完整实例
Jan 28 jQuery
JavaScript 监听组合按键思路及代码实现
Jul 28 Javascript
vue3.0封装轮播图组件的步骤
Mar 04 Vue.js
用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中文件读、写、删的操作(PHP中对文件和目录操作)
2012/03/06 PHP
php使用GD创建保持宽高比缩略图的方法
2015/04/17 PHP
基于thinkPHP实现的微信自定义分享功能示例
2016/09/23 PHP
Laravel Eloquent分表方法并使用模型关联的实现
2019/11/25 PHP
用javascript获得地址栏参数的两种方法
2006/11/08 Javascript
基于jquery的商品展示放大镜
2010/08/07 Javascript
javascript中onclick(this)用法介绍
2013/04/19 Javascript
JQuery伸缩导航练习示例
2013/11/13 Javascript
Java中Timer的用法详解
2015/10/21 Javascript
3种js实现string的substring方法
2015/11/09 Javascript
解决wx.onMenuShareTimeline出现的问题
2016/08/16 Javascript
Bootstrap CSS布局之表单
2016/12/17 Javascript
解析JavaScript模仿块级作用域
2016/12/29 Javascript
Vue开发之封装上传文件组件与用法示例
2019/04/25 Javascript
layui 阻止图片上传的实例(before方法)
2019/09/26 Javascript
layer页面跳转,获取html子节点元素的值方法
2019/09/27 Javascript
vue中进行微博分享的实例讲解
2019/10/14 Javascript
[06:53]DOTA2每周TOP10 精彩击杀集锦vol.3
2014/06/25 DOTA
python使用PyFetion来发送短信的例子
2014/04/22 Python
Python 读写文件和file对象的方法(推荐)
2016/09/12 Python
python 使用poster模块进行http方式的文件传输到服务器的方法
2019/01/15 Python
Python Sympy计算梯度、散度和旋度的实例
2019/12/06 Python
pytorch方法测试详解——归一化(BatchNorm2d)
2020/01/15 Python
pytorch dataloader 取batch_size时候出现bug的解决方式
2020/02/20 Python
matplotlib基础绘图命令之errorbar的使用
2020/08/13 Python
python实现简单贪吃蛇游戏
2020/09/29 Python
纪伊国屋泰国网上书店:Kinokuniya泰国
2017/12/24 全球购物
Notino芬兰:购买香水和化妆品
2019/04/15 全球购物
英国川宁茶官方网站:Twinings茶
2019/05/21 全球购物
酒店管理专业毕业生推荐信
2013/11/10 职场文书
幼儿园开学家长寄语
2014/01/19 职场文书
中专自我鉴定
2014/02/05 职场文书
2015年教师个人业务工作总结
2015/10/23 职场文书
2016优秀护士先进个人事迹材料
2016/02/25 职场文书
Nginx快速入门教程
2021/03/31 Servers
手把手教你实现PyTorch的MNIST数据集
2021/06/28 Python