That way I want to stay

BlogJava 首页 新随笔 联系 聚合 管理
  55 Posts :: 1 Stories :: 41 Comments :: 0 Trackbacks

目前jQuery网站上已经有了From的验证框架,FromValidation,但是一直觉得它的框架并不好用,因为重复写的东西太多了。
于是就再次写了自己的JavaScript验证框架,完全废弃掉以前的。
在新的框架下,是以这样子的用法设计的:
首先,要包括自己的js文件(这点不必说),而且在包括自己写,要先包括jQuery的,如下

<link rel="stylesheet" type="text/css" href="<ww:url value="/layout/css/style.css"/>">
<link rel="stylesheet" type="text/css" href="<ww:url value="/layout/css/thickbox.css"/>" media="screen">
<script type="text/javascript" src="<ww:url value="/layout/js/jquery-latest.js"/>"></script>
<script type="text/javascript" src="<ww:url value="/layout/js/thickbox.js"/>"></script>
<script type="text/javascript" src="<ww:url value="/layout/js/wingel.js"/>"></script>
<decorator:head/>


然后在要验证的Form里面加个属性validatable=true,如下:

<form id="registerForm" action="user-register.action" validatable="true">

注意,这边不要加onsubmit方法

接下来,就好了,比如说有个输入框:
<ww:textfield name="name" id="name"/>
我想验证,让它必填,如下就可以了:
<label for="name" validate="required">请填写名称</label>  其中 for属性里面填的要是验证的输入框id,validate填的是验证方法,;label里面的文本就是验证不过的时候要显示的信息。
如果我想验证一个输入框的输入值长度怎么办,这样子就行了

<label for="password" validate="lengthRange:6;20">

后面的参数用;号隔开,验证的方法名跟参数用: 隔开。
wingel.js里面已经包括了一些常用的验证方法,现在问题来了,如果要自定义验证方法怎么办,如下办:
比如你想加个验证方法是hello
则label里面的validate属性写成hello,
然后加一个JavaScript方法:

<script type="text/javascript">
    wingel.validator.rules.hello
= function(value, element, parameters,utility) {
             ...    }

</script>


里面三个参数,shit , couldn't input Chinese. now English will be used.

The first parameter is the value of the input element you want to validate,the second one is the validated element, the third one, is the parameters you add in validate label, the last one, is a utility class, you can invoke its method to make your code easier.






 
文章来源:http://blog.csdn.net/Wingel/archive/2006/11/26/1414856.aspx
posted on 2006-11-29 11:21 Wingel 阅读(255) 评论(0)  编辑  收藏

只有注册用户登录后才能发表评论。


网站导航: