当前位置: 代码迷 >> Web前端 >> jquery应验
  详细解决方案

jquery应验

热度:298   发布时间:2012-06-27 14:20:09.0
jquery验证
项目中时常会用到一些验证手段...由于在开发前需要对一些技术的定位!所以一般选择固定的验证框架和技术.
我在前台验证中使用的是jquery_validator.这是个容易上手的框架.个人感觉它和struts2结合在一起非常不错.下面讲下使用的过程.
准备的jar包:struts2可以到http://struts.apache.org/download.cgi下载
juery_validator可以到http://plugins.jquery.com/project/validate下载
jquery_validator的介绍:
一.默认校验规则
(1)required:true 必输字段
(2)remote:"check.php" 使用ajax方法调用check.php验证输入值
(3)email:true 必须输入正确格式的电子邮件
(4)url:true 必须输入正确格式的网址
(5)date:true 必须输入正确格式的日期
(6)dateISO:true 必须输入正确格式的日期(ISO),例如:2009-06-23,1998/01/22 只验证格式,不验证有效性
(7)number:true 必须输入合法的数字(负数,小数)
(8)digits:true 必须输入整数
(9)creditcard: 必须输入合法的信用卡号
(10)equalTo:"#field" 输入值必须和#field相同
(11)accept: 输入拥有合法后缀名的字符串(上传文件的后缀)
(12)maxlength:5 输入长度最多是5的字符串(汉字算一个字符)
(13)minlength:10 输入长度最小是10的字符串(汉字算一个字符)
(14)rangelength:[5,10] 输入长度必须介于 5 和 10 之间的字符串")(汉字算一个字符)
(15)range:[5,10] 输入值必须介于 5 和 10 之间
(16)max:5 输入值不能大于5
(17)min:10 输入值不能小于10

默认的提示在jquery_validate.js源码中可以看到是英文的提示:
messages: {.....}
可以自己进行修改.不过jquery_validate本来就提供了各个语言的包就在下载的jquery.validate.zip中localization包下.使用中文可以导入messages_cn.js;

下面是例子的开始:
整个项目的部署过程就不说了。下面会有例子上传
讲些重点.
reg.jsp:
Java代码 
<link href="css/jquery_validate.css" rel="stylesheet" type="text/css"/> 
<script type="text/javascript" src="js/jquery.js"></script> 
<script type="text/javascript" src="js/jquery_validate.js"></script> 
<script type="text/javascript" src="js/jquery.metadata.js"></script> 
</head> 
<script type="text/javascript"> 
$(function() { 
    $("#jvForm").validate(); 
}); 
</script> 
<body> 
<form action="" method="post" id="jvForm"> 
<table> 
<tr> 
<td>name:</td> 
<td><input type="text" name="bean.name"  class="{required:true,remote:'admin/core/ajax/checkUserName.action',messages:{remote:'用户名已存在!'}}"/></td> 
</tr> 
<tr> 
<td>password:</td> 
<td><input type="password" name="bean.password" class="required"/></td> 
</tr> 
<tr> 
<td colspan="2"><input type="submit" value="提交"/></td> 
</tr> 
</table> 
</form> 

首先引入jquery_validate.css.对提示的内容进行css格式的修改.
jquery.metadata.js可以提供
使用class="{}"的方式,可以使用如下的方法,修改提示内容:
class="{required:true,minlength:5,messages:{required:'请输入内容'}}"在使用equalTo关键字时,后面的内容必须加上引号,如下代码:
class="{required:true,minlength:5,equalTo:'#password'}"
它的其他几种表现方式就不介绍了.因为各个感觉这种表现形式是最好用的.
用户名的检测中我们做了一个模拟检验用户名是否存在(这种操作在项目中也是比较常见.对于一些名字不可以重复的进行提示).我们访问了checkName.action.下面看看相应的Action实体:
AdminAjaxAct
Java代码 
public class AdminAjaxAct implements Action{ 
     
 
    /**
     * 判断前台用户注册
     * 
     * @return
     */ 
    public String checkUserName() { 
        String username = bean.getName(); 
        boolean b = true; 
        if (StringUtils.isBlank(username)) { 
            b = false; 
        } 
         
        if (b) { 
            b = "test".equals(username); 
        } 
        //如果用户名存在.就代表检验用户存在 
        //所以用户不能提交 
        return renderText(b ? "false" : "true"); 
    } 
 
    /**
     * 绕过Template,直接输出内容的简便函数.对常用的数据进行抽取.提高
            *提高重用性
     */ 
    protected String render(String text, String contentType) { 
        try { 
            HttpServletResponse response = ServletActionContext.getResponse(); 
            response.setContentType(contentType); 
            response.getWriter().write(text); 
        } catch (IOException e) { 
        } 
        return null; 
    } 
 
    /**
     * 直接输出字符串.
     */ 
    protected String renderText(String text) { 
        return render(text, "text/plain;charset=UTF-8"); 
    } 
 
    private Admin bean; 
 
 
 
    public Admin getBean() { 
        return bean; 
    } 
 
 
 
    public void setBean(Admin bean) { 
        this.bean = bean; 
    } 
 
 
 
    @Override 
    public String execute() throws Exception { 
        return SUCCESS; 
    } 
     
     


StringUtils:apache提供的工具包(挺好用).因为要符合jquery_validator的形式所以输出的要为true.false方便以信息的形式进行提示.

从中就可以感觉到.在使用jquery_validator的时候使用struts2的OGNL表达式的原型完成可以整在一起.他传递参数也同样是使用是将对象的引用值用点串联起来.如bean.name;

详细参考
http://www.f6n.net/blog/web/200901129415.html
  相关解决方案