JavaScript 开发中规范性的一点感想


Posted in Javascript onJune 23, 2009

可谓一劳永逸,不要重复造轮子:)
1.常用的方法统一放置
例如:在用户注册时,时常需要判断文本框中字符是否是汉字、英文、数字或邮箱地址等等。何不把这些方法统一放在一个脚本中,取名叫做utility.js呢?

//待需要时另存为一个js function isNull(obj) 
{ 
if (!obj || obj.length==0 || obj=="") 
{ 
parent.MyAlert("标注名不能为空!",alertImg); 
return false; 
} 
else 
{ 
return true; 
} 
} 
// 验证是否为整数 
function isNumber(oNum) 
{ 
if(!oNum) return false; 
try{ 
if(parseInt(oNum)!=oNum) { 
parent.MyAlert("查询距离请填写正整数!",alertImg); 
return false; 
} 
} 
catch(ex) 
{ 
parent.MyAlert("查询距离请填写正整数!",alertImg); 
return false; 
} 
return true; 
} 
// 验证是否为中文 
function isChinese(oCn) 
{ 
if (!oCn || oCn.length==0) return false; 
try{ 
var reg = /^[\u4e00-\u9fa5]+$/i; //含中文 
if ( reg.test(oCn) ) 
{ 
return true; 
} 
else{ 
parent.MyAlert("关键字请填写中文!",alertImg); 
return false; 
} 
} 
catch(ex) 
{ 
parent.MyAlert("关键字请填写中文!",alertImg); 
return false; 
} 
} 
// 验证是否为中文或字母 
function isEnCh(oStr) 
{ 
if (!oStr || oStr.length==0) return false; 
try{ 
var reg = /^[a-zA-Z\u4E00-\u9FA5]/g; //含中文或拼音 
if ( reg.test(oStr) ) 
{ 
return true; 
} 
else{ 
parent.MyAlert("地名请填写中文或拼音!",alertImg); 
return false; 
} 
} 
catch(ex) 
{ 
parent.MyAlert("地名请填写中文或拼音!",alertImg); 
return false; 
} 
} 
// 结果保留2位小数 
function roundAmount(n){ 
var s = "" + Math.round(n * 100) / 100; 
var i = s.indexOf('.') 
if (i < 0) return s + ".00"; 
var t = s.substring(0, i + 1) + s.substring(i + 1, i + 3); 
if (i + 2 == s.length) t += "0"; 
return t; 
}

2.提示、报错信息统一放置

看了上面的代码,您是否也发现一个问题:下一个项目中如果提示、报错信息不一样,还需要重新改动上述代码。何不把提示信息统一放在一个脚本中,取名叫做resource_zh.js呢?

在多语言版本的软件中,也有用类似的招数达到切换界面语言,有发现?呵呵。

var page_res = { 
    "meter": "米", 
    "kilometer": "千米(公里)", 
    "mile": "英里", 
    "yard": "码", 
    "degree": "度", 
    "millimeter": "毫米", 
    "saveMap": "保存地图", 
    "printMap": "打印地图", 
    "queryResult": "查询结果", 
    "queryResultNull": "查询结果为空", 
    "experssionCanNotNull": "查询表达式不能为空", 
    "networkInfo": "路径信息", 
    "arcInfo": "弧段信息", 
    "addEntitySuccess": "添加地物成功! ", 
    "addEntityFail": "添加地物失败!", 
    "updateEntitySuccess": "更新地物成功!", 
    "updateEntityFail": "更新地物失败!", 
    "updatePropertySuccess": "更新属性成功!", 
    "updatePropertyFail": "更新属性失败!", 
    "deleteEntitySuccess": "删除地物成功!", 
    "deleteEntityFail": "删除地物失败!", 
    "closestFacilityFail": "最近设施分析失败,请重新选择", 
    "fieldCanNotNull": "字段数不能为空", 
    "fieldMustInteger": "字段数必须为整数", 
    "fieldMustMoreThanZero": "字段数必须大于0", 
    "numberCanNotNull": "数值不能为空" 
}

我们可以把常用的单位、按钮文本、提示信息都放在这里。然后最先加载该脚本,通过eval实例化出一个对象。通过类似res.networkInfo便可获得对应的内容。

3.AjaxRequest请求封装

跟第一点意义是一致的,在现在开发中频繁使用Ajax,如果您没用jQuery等脚本库的话,可能是自己写每次请求和回调的函数。何不把这些方法都放在一个ajax.js中呢?

var xmlhttpObj=false; 
function XHR(CallBack) 
{ 
this.callback=CallBack; 
} 
XHR.createXMLHttp = function () 
{ 
if(window.ActiveXObject) //IE浏览器 
{ 
try 
{ 
xmlhttpObj = new ActiveXObject("Microsoft.XMLHTTP");//IE4.0 
} 
catch (e) 
{ 
try 
{ 
xmlhttpObj = new ActiveXObject("Msxml2.XMLHTTP");//IE5.0以上 
} 
catch (e2) 
{ 
xmlhttpObj=false; 
} 
} 
} 
else if(window.XMLHttpRequest&&!xmlhttpObj) //开放浏览器 
{ 
xmlhttpObj = new XMLHttpRequest(); 
} 
} 
XHR.prototype.Onstar = function (method,Url,bFlag,param) 
{ 
if(this.callback!=null) 
{ 
XHR.createXMLHttp(); 
xmlhttpObj.onreadystatechange=this.callback; 
xmlhttpObj.open(method,Url,bFlag); 
xmlhttpObj.setRequestHeader("Content-Type","application/x-www-form-urlencoded;"); 
xmlhttpObj.send(param); 
} 
else 
{ 
alert("没有客户端处理函数!") 
} 
}

在使用时实例化一个XHR对象出来,例如:var legendObj=new XHR(function (){...}); 然后用legendObj.Onstar("POST","Handlers/legendHandler.ashx",false,"mapName=" + mapName);提交请求即可。
Javascript 相关文章推荐
jQuery 写的简单打字游戏可以提示正确和错误的次数
Jul 01 Javascript
jQuery中:checkbox选择器用法实例
Jan 03 Javascript
RequireJS入门一之实现第一个例子
Sep 30 Javascript
Bootstrap 粘页脚效果
Mar 28 Javascript
将form表单通过ajax实现无刷新提交的简单实例
Oct 12 Javascript
详解微信小程序 wx.uploadFile 的编码坑
Jan 23 Javascript
简单实现bootstrap导航效果
Feb 07 Javascript
vue.js指令v-model使用方法
Mar 20 Javascript
基于vue,vue-router, vuex及addRoutes进行权限控制问题
May 02 Javascript
小程序云开发实战小结
Oct 25 Javascript
react的滑动图片验证码组件的示例代码
Feb 27 Javascript
Vue使用预渲染代替SSR的方法
Jul 02 Javascript
jQuery 表单验证插件formValidation实现个性化错误提示
Jun 23 #Javascript
一个很酷的拖动层的js类,兼容IE及Firefox
Jun 23 #Javascript
一些常用的JS功能函数代码
Jun 23 #Javascript
JQuery 无废话系列教程(二) jquery实战篇上
Jun 23 #Javascript
JQuery 无废话系列教程(一) jquery入门 [推荐]
Jun 23 #Javascript
IE JS编程需注意的内存释放问题
Jun 23 #Javascript
js form 验证函数 当前比较流行的错误提示
Jun 23 #Javascript
You might like
咖啡的种类和口感
2021/03/03 新手入门
php下一个阿拉伯数字转中文数字的函数
2007/07/16 PHP
php验证session无效的解决方法
2014/11/04 PHP
thinkPHP引入类的方法详解
2016/12/08 PHP
docker-compose部署php项目实例详解
2019/07/30 PHP
PHP 图片处理
2020/09/16 PHP
jquery在项目中做复选框时遇到的一些问题笔记
2013/11/17 Javascript
JS 仿腾讯发表微博的效果代码
2013/12/25 Javascript
jQuery关键词说明插件cluetip使用指南
2015/04/21 Javascript
网页前端登录js按Enter回车键实现登陆的两种方法
2016/05/10 Javascript
浅谈js基本数据类型和typeof
2016/08/09 Javascript
js原生代码实现轮播图的实例讲解
2017/07/28 Javascript
Three.js实现3D机房效果
2018/12/30 Javascript
5分钟快速看懂ES6中的反射与代理
2019/12/19 Javascript
python实现爬虫下载漫画示例
2014/02/16 Python
自己使用总结Python程序代码片段
2015/06/02 Python
python开发之thread实现布朗运动的方法
2015/11/11 Python
windows系统下Python环境搭建教程
2017/03/28 Python
python获取服务器响应cookie的实例
2018/12/28 Python
Python 3.8 新功能来一波(大部分人都不知道)
2020/03/11 Python
aws 通过boto3 python脚本打pach的实现方法
2020/05/10 Python
Guess欧洲官网:美国服饰品牌
2019/08/06 全球购物
会计自我鉴定范文
2013/10/06 职场文书
创先争优制度
2014/01/21 职场文书
工厂总经理岗位职责
2014/02/07 职场文书
监察建议书范文
2014/03/12 职场文书
2014年教师党员公开承诺书
2014/05/28 职场文书
工作目标责任书
2014/07/23 职场文书
建筑管理专业求职信
2014/07/28 职场文书
银行党的群众路线教育实践活动对照检查材料
2014/09/25 职场文书
师德师风个人整改措施
2014/10/27 职场文书
成事在人观后感
2015/06/16 职场文书
2016年教师节慰问信
2015/12/01 职场文书
用python批量解压带密码的压缩包
2021/05/31 Python
基于PostgreSQL/openGauss 的分布式数据库解决方案
2021/12/06 PostgreSQL
MongoDB修改oplog大小的四种方法
2022/04/11 MongoDB