当前位置: 移动技术网 > IT编程>开发语言>JavaScript > formvalidator验证插件中有关ajax验证问题

formvalidator验证插件中有关ajax验证问题

2019年01月14日  | 移动技术网IT编程  | 我要评论

jquery formvalidator插件是不错的国产验证插件了,做点普通的校验也是很方便的,但最近遇到个问题,发现如果表单整个表单是ajax提交时,就不能按传统的做法了,比如:

代码如下:


$ajax.post("...............")
$.formvalidator.initconfig({formid:"applyform",onerror:function(msg){alert(msg)}});
$("#reason").formvalidator().inputvalidator({min:1,onerrormin:'请输入申请内容及原因'});


很遗憾,单这样是达不到ajax form提交并同时用formvalidator校验的效果的。如果要同时使用formvalidator和ajax提交一起的话,首先看到的是formvalidtor手册中关于ajaxform的用法

. 代码如下:


$.formvalidator.initconfig({theme:"default",submitonce:true,formid:"form1",ajaxform:{
datatype : "html",
buttons:$("#button"),
url: "https://www.51gh.net/chkuser.x?act=ok"
},
onerror:function(msg,obj,errorlist){
$("#errorlist").empty();
$.map(errorlist,function(msg){
$("#errorlist").append("[*]" + msg + "
")
});
alert(msg);
},
submitafterajaxprompt : '有数据正在异步验证,请稍等...'
});


看了下,这个方法看上去是可以的,但实际上,居然对中文支持不好,我的是
struts2,spring 3,tomcat也是用utf-8,sturts2等全部用utf-8编码了,但居然还是说当取的
struts2的中文值的时候,说:
org.apache.tomcat.util.http.parameters processparameters
警告: parameters: character decoding failed. parameter skipped.
java.io.charconversionexception: ishexdigit.
解决方式见
https://www.iteye.com/problems/7099
但这个问题很奇怪,而且感觉用formvalidtor本身的方法太麻烦,所以就找了另外的方法,果然好用,那就是使用

. 代码如下:


if ($.formvalidator.pageisvalid('1')==true)
{
$.post("xxxxxxxxxxxxxxxxx")
}


其他校验规则照样写,如果页面只有一个表单,则默认为1,这里的pageisvalid,是校验这个组的控件所有都通过校验了,就继续做某事,你看,这样就简单多了。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网