JS客户端校验

在最近的一个项目中,用到了几种客户端校验方式,在这里和大家探讨一下。

第一种是最一般的js客户端校验,在提交表单的时候触发js里的一个方法,在这个方法里校验客户所填的数据是否合法,并给予提示。
例如:
[code]<script>
function submitForm()
{
var userName = document.getElementById("userName").value;
if(userName==""){
alert("姓名不能为空!");
document.getElementById("userName").focus();
return false;
}
document.form.submit();
}
</script>[/code]
在JSP页面里
[code] <button οnclick=”submitForm();”>提交</button> [/code]
这样一旦用户名为空,就会弹出一个对话框。这种方式比较古老,显示的对话框也不大美观。


第二种是利用例如文本框得到和失去焦点时调用不同的方法来实现校验,可以参考赶集网的校验方式:[url]http://tetlaw.id.au/view/javascript/really-easy-field-validation[/url]。
简单的例子如下:
JS:
[code]
function click_email_input(thisinput)
{
document.getElementById('regemailinfo').className='s1';
document.getElementById('regemailinfo').innerHTML="请输入有效Email(电子邮件)";
}
//失去Email焦点
function check_email_input(thisinput)
{
var re = /^[_\.0-9a-zA-Z-]+[0-9a-zA-Z]@([0-9a-zA-Z][0-9a-zA-Z-]+\.)+[a-zA-Z]{2,3}$/;

if ( (thisinput.value == '') ) {
document.getElementById('regemailinfo').className="s2";
document.getElementById('regemailinfo').innerHTML="系统检测到你未有任何输入,此项为必填内容,请重新填写!";

else if (!thisinput.value.match(re))
{
document.getElementById('regemailinfo').className = 's2';
document.getElementById('regemailinfo').innerHTML = '你输入的内容不符合规范,请重新填写!';
}

else
{
document.getElementById('regemailinfo').className = 's3';
document.getElementById('regemailinfo').innerHTML = '输入的内容符合规范,可以使用!';
}
}
[/code]
JSP片段:

[code]
<tr>
<th scope="row"><div align="left"><span class="STYLE2">电子邮件:</span></div></th>
<td>
<div align="left">
<input name="email" id="email" type="text" size="30" οnblur="check_email_input(this)" οnfοcus="click_email_input(this)"/>
</div></td>
<td><span id="regemailinfo" class=""></span></td>
</tr>
[/code]
当鼠标点击文本框的时候调用click_email_input(this) 方法,离开文本框的时候调用check_email_input(this) 方法,改变span的CSS属性和span的内容来提示用户。这种方式给人以十分绚丽的感觉。


第三种方式是比较流行的,使用扩展基于prototype的validation.js ,
[code]
<script src="prototype.js" type="text/javascript"></script>
<script src="validation.js" type="text/javascript"></script>
<link rel="stylesheet" type="text/css" href="style.css" />
[/code]
接着为表单控件设置class属性,属性名为预定义的(可扩展)的校验器名

[code]
<input class="required validate-number" id="field1" name="field1" />[/code]
最后创建一个 Validation 对象,以表单id为构造函数的参数

[code]
<script type="text/javascript">
new Validation('form-id');

</script>
[/code]
使用相当的简单,最可贵的就是假如脚本未能加载成功或者浏览器端的脚本被禁用,原始的表单仍然可以按传统的方式进行提交(配合后台校验),这可算是优雅的 Unobtrusive JavaScript 的又一个经典范例。

下面是一个最简单的例子:
[code]
<body>


<form action="" id="test_form">

金额:
<input class="required validate-number" id="sum" name="sum" title="必须填写有效金额."/>


<input name="submit" type="submit" value="提交"/>

</form>
<script type="text/javascript">

var valid = new Validation('test_form', {useTitles : true});

</script>
</body>
[/code]


在表单控件的class属性中,required表示不能用空,validate-number表示所填内容必须为数字,
还有title属性表示显示错误信息的内容。最后创建一个 Validation 对象,以表单id为构造函数的参数,useTitles属性默认为false,表示显示错误信息为默认信息,把该属性设为true,则显示的错误信息为title属性所定义的内容。也可以假如其他属性,例如:immediate,默认也为false,在提交表单的时候才进行校验,把该属性设为true,则在表单控件失去焦点的时候丢相应空间进行校验。如果里面的校验类型还不能满足你的要求,也可以自定义校验类型
只需要添加
[code]
Validation.addAllThese([
['validate-password', 'Your password must be more than 6 characters and not be \'password\' or the same as your name', {
minLength : 7,
notOneOf : ['password','PASSWORD','1234567','0123456'],
notEqualToField : 'field1'
}],
['validate-password-confirm', 'Your confirmation password does not match your first password, please try again.', {
equalToField : 'field8'
}]
]);
[/code]

这个方法增加了密码和重复密码的校验。


从 validation.js 里截取的一段源码看其实现机制:

......
Event.observe(this.form,'submit',this.onSubmit.bind(this),false);
......由上代码可知该库注册了表单的 onsubmit 事件处理,当用户电击submit按钮的时候,校验被触发。
不过我在实际应用中遭遇了麻烦,因为我是用一个普通按钮调用JS的一个方法来模拟 submit 按钮的, 问题就在于,由JavaScript代码模拟的提交行为居然是不激发 onsubmit 事件的,这样设置的校验行为就被直接跳过了。各位有什么好的建议请留言。


还有一个问题就是,错误信息显示的位置是固定的,都是在表单控件的下方,想要在特定的位置显示错误信息还要进行一些处理。

可以使用
[code]
<div id="advice-validate-one-required-test[]">
</div>
[/code]

id的模式等于:
[code]
advice-$validatorName-$elementId
[/code]

例如:
[code]
<div>
<input type="checkbox" name="test[]"> a
<input type="checkbox" name="test[]"> b
<input type="checkbox" name="test[]" class="validate-one-required
"> c
</div>
<div id="advice-validate-one-required-test[]"></div>
[/code]

这样错误信息就显示在DIV中。这个例子是别人提供的,他想要的效果都出来了,但我自己试了一下:
[code]
<div align="left">
<input class="required " title="请输入密码." name="pwd" id="pwd" type="password" size="25"/>
</div>

<div id="advice-required-pwd">请输入密码</div>

<script type="text/javascript">
new Validation('form',{useTitles : true,immediate : true});
</script>
[/code]


当输入信息符合要求时,DIV(id=advice-required-pwd)里的信息就会消失,将输入信息去掉,DIV里的错误信息又会出现。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值