注册验证代码整理(dwr+js)

[b][url=http://www.bestown.cn]百事通信息网[/url][/b]


1、校验工具类
[code]function ChkUtil() { }
//定位焦点
ChkUtil.onFocus = function (obj) {
if (obj) {obj.focus();}
};
//删除串两边空格
ChkUtil.trim = function (str) {
var patrn = /(^\s+|\s$)/g;
return str.replace(patrn, "");
};
//校验是否为空(先删除二边空格再验证)
ChkUtil.isNull = function (str) {
if (null == str || ""== ChkUtil.trim(str)) {
return true;
} else {
return false;
}
};
//校验是否全由数字组成
ChkUtil.isDigit = function (digit) {
var patrn = /^[0-9]{1,20}$/;
return patrn.test(digit);
};
//校验字符串:只能输入6-20个字母、数字、下划线
ChkUtil.isString6_20=function(str){
var patrn=/^(\w){6,20}$/;
return patrn.test(str);
};
//校验电话号码
ChkUtil.isMobile = function (mobile) {
var patrn = /^[+]{0,1}(\d){1,3}[ ]?([-]?((\d)|[ ]){1,12})+$/;
return patrn.test(mobile);
};
//校验电邮地址
ChkUtil.isEmail = function (email) {
var patrn = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/;
return patrn.test(email);
};[/code]
前端应用代码:
[code] <script type='text/javascript' src='../../dwr/interface/DWRUser.js'></script>
<script type='text/javascript' src='../../dwr/engine.js'></script>
<script type='text/javascript' src='../../dwr/util.js'></script>
<script type='text/javascript' src='../js/chked.js'></script>
<script type='text/javascript'>
//具体表单验证类
var RegChked=function(){
this.flg=true;
this.userMsg="";
this.pswdMsg="";
this.userChk=function(username){
if(!ChkUtil.isString6_20(username)){
this.userMsg="用户名不正确!";
this.flg=false;
}else{
DWRUser.isExist(username,callBack);
}
};
this.pswdChk=function(password,password2){
if(!ChkUtil.isString6_20(password)){
this.pswdMsg="密码不正确!";
this.flg=false;
}else{
if(password!=password2){
this.pswdMsg="密码不一致!";
this.flg=false;
}
}
};
var callBack=function(data){
if(data){
DWRUtil.setValue("userMsg","该用户名已经被注册!");
this.flg=false;
}
};
}
//表单提交前调用函数(οnsubmit="return onChked()")
function onChecked(){
var rc=new RegChked();
rc.userChk($("username").value);
rc.pswdChk($("password").value,$("password2").value);
if(rc.flg){
return true;
}else{
var errors={userMsg:rc.userMsg,pswdMsg:rc.pswdMsg};
DWRUtil.setValues(errors);
return false;
}
}
</script>
<body>
<html:form action="/userCenter?method=regedit" method="post" οnsubmit="return onChked()" >
<table border="0" align="center" width="500">
<tr>
<td width="100">用户名:</td>
<td width="200">
<html:text property="username"/>
</td>
<td>
<div id="userMsg"></div>
</td>
</tr>
<tr>
<td>密码:</td>
<td>
<html:password property="password" />
</td>
<td>
<div id="pswdMsg"></div>
</td>
</tr>
<tr>
<td>确认密码:</td>
<td>
<html:password property="password2" />
</td>
<td>
<br>
</td>
</tr>
<tr>
<td colspan="2" align="center">
<html:submit value=" 注册 " />
</td>
<td>
<br>
</td>
</tr>
</table>
</html:form>
</body>[/code]

上述代码中存在异步问题,网上看了一些资料,有用信号量来同步的,不过用js信号量的算法怎么来定,没有头绪
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值