Js表单验证控件-02 Ajax验证
在《Js表单验证控件(使用方便,无需编码)-01使用说明》中,写了Verify.js验证控件的基本用法,基本可以满足大多数验证需求,如果涉及服务端的验证,则可以通过Ajax。
Ajax验证有两种,一种是前端验证,一种是请求服务器端的验证,例如验证密码是否正确。
前端验证很简单,verify.js验证控件的基本原理就是点击验证按钮时,遍历各处控件上的验证属性,如果不满足验证条件,则返回false; 当ajax异步验证时只是调用了验证按钮的事件。
如下,验证表单中的b组控件
Verify.IsPass($("form"),"b")
概述
Verify.js所提供的验证方法,都是基于前端技术,针对一些需要与服务器端交互的验证,例如验证码、短信验证、登录验证等,需要接合Ajax的方式异步与服务器端交互,返回判断结果。 根据判断结果,指定具体的某个控件校验证失败,并显示提示。
相较于之前的验证方式(只用增加控件属性即可实现验证),Ajax的代码编写略显复杂,如果熟悉Javascrpt代码编写,其实也很简单。 如下代码,是在指定的控件上显示错误提示信息。
Verify.ShowBox($("form input[name=tbPhone]"), "该手机号未在系统中注册!");
示例
1、Javascript单独验证某个控件
注意,下述代码中没有form标签,不再通过form的提交事件进行验证,而是手工编写Javascript代码对任一一个控件进行单独验证。
绿色的按钮只是一个普通的Div标签,只是样式像个按钮。
<p> 姓名:
<input name="name" type="text" size="6" datatype="chinese"
place="right" lenlimit="2-4" alt="限2至4个中文字/符">
<span>(限中文)</span> </p>
<p> 年龄:
<input type="text" name="age" size="4" datatype="uint" nullable="false" place="right" />
</p>
<p>
<div class="btn" id="btn">验证表单(div)</div>
</p>
<script type="text/javascript">
$("#btn").click(function(){
if(Verify.IsPass($("input[type=text][name=name]"))){
alert("姓名录入合格");
};
if(Verify.IsPass($("input[type=text][name=age]"))){
alert("年龄录入合格");
};
});
</script>
姓名: (限中文)
年龄: *
2、Javascript批量验证控件
当点击按钮时,可以实现对form表单内的控件进行分组验证,全部通过则返回true,否则返回false。该过程不会触发form的submit事件。
form在此处可以仅仅作为一个容器。
<form place="right">
<p> 账号:
<input name="" type="text" nullable="false" datatype="user" group="a"/>
(a组) </p>
<p> 姓名:
<input name="" type="text" size="6" datatype="chinese" lenlimit="2-4" group="b" alt="限2至4个中文字/符">
<span>(b组)</span> </p>
<p> 年龄:
<input type="text" size="4" datatype="uint" nullable="false" place="right" group="a|b"/>
(ab组) </p>
<p> 电话:
<input type="text" datatype="mobile|tel" nullable="false" alt="请输入正确的电话号码" group="b">
(b组) </p>
<p> 邮箱:
<input type="text" datatype="email" nullable="false" />
(没有组) </p>
<p>
<div class="btn" id="btnA">验证A组(div)</div>
<div class="btn" id="btnB">验证B组(div)</div>
<div class="btn" id="btnAB">验证AB组(div)</div>
<div class="btn" id="btnNull">验证没有组(div)</div>
</p>
<script type="text/javascript">
$("#btnA").click(function(){
if(Verify.IsPass($("form"),"a")){
alert("a组验证通过");
};
});
$("#btnB").click(function(){
if(Verify.IsPass($("form"),"b")){
alert("b组验证通过");
};
});
$("#btnAB").click(function(){
if(Verify.IsPass($("form"),"a|b")){
alert("ab组验证通过");
};
});
$("#btnNull").click(function(){
if(Verify.IsPass($("form"))){
alert("没有分组的控件验证通过");
};
});
</script>
</form>
账号: * (a组)
姓名: (b组)
年龄: * (ab组)
电话: * (b组)
邮箱: * (没有组)
3、通过Ajax回调,手动显示错误提示
注意,Ajax的调用必须是在http状态下。
<p> 姓名:
<input name="name2" type="text" size="6"
datatype="chinese" place="right" lenlimit="2-4" alt="请输入中文">
<span>(限中文)</span> </p> <p>
<div class="btn" id="btnGet">验证表单(div)</div>
</p>
<script type="text/javascript">
$("input[name=button2]").click(function(){
$.get("1-1.htm",function(){
Verify.ShowBox($("input[type=text][name=name2]"),"姓名已经存在");
});
});
</script>
Js表单验证控件-02 Ajax验证的更多相关文章
- 【ASP.NET 基础】表单和控件
1.HTML表单的提交方式 对于一个普通HTML表单来说,它有两个重要的属性:action 和 method.action属性指明当前表单提交之后由哪个程序来处理,这个处理程序可以是任何动态网页或者 ...
- ASP.NET开发中主要的字符验证方法-JS验证、正则表达式、验证控件、后台验证
ASP.NET开发中主要的字符验证方法-JS验证.正则表达式.验证控件.后台验证 2012年03月19日 星期一 下午 8:53 在ASP.NET开发中主要的验证方法收藏 <1>使用JS验 ...
- 详解Ajax请求(三)——jQuery对Ajax的实现及serialize()函数对于表单域控件参数提交的使用技巧
原生的Ajax对于异步请求的实现并不好用,特别是不同的浏览器对于Ajax的实现并不完全相同,这就意味着你使用原生的Ajax做异步请求要兼顾浏览器的兼容性问题,对于java程序员来讲这是比较头疼的事情, ...
- [WPF自定义控件库]简单的表单布局控件
1. WPF布局一个表单 <Grid Width="400" HorizontalAlignment="Center" VerticalAlignment ...
- HTML之表单类控件、图像类元素的CSS特别样式汇总
前言 记录下开发过程中一些特殊表单控件(input.textarea.select等)的样式控制 input 取消光标聚焦时,输入框的外延边框 input:focus{ outline:none } ...
- jeecg表单页面控件权限设置(请先看官方教程,如果能看懂就不用看这里了)
只是把看了官方教程后,觉得不清楚地方补充说明一下: 1. 2. 3. 4.用"jeecgDemoController.do?addorupdate"这个路径测试,不出意外现在应该可 ...
- 使用jquery.validate.js插件进行表单里控件的验证
jsp中具体实现的代码: <%@ page language="java" contentType="text/html; charset=UTF-8" ...
- ASP.NET验证控件CustomValidator客户端验证DropDownList、TextBox
<asp:DropDownList ID="ddlTown" runat="server"> <asp:ListItem Value=&quo ...
- ASP.NET_验证控件(class0620)
为什么使用验证控件 当需要让用户输入数据时,用户有可能输入不符合我们程序逻辑要求的信息,所以我们要对输入进行验证. 客户端验证(用户体验,减少服务器端压力) 服务器端验证(防止恶意攻击,客户端js很容 ...
随机推荐
- React将某段文字插入到某个元素里
最基本使用: 引入依赖文件: <script src="https://unpkg.com/react@16/umd/react.development.js">< ...
- xml实现登录表单验证
定义: XML(eXtended Markup Language,可扩展标记语言)提供了一套跨平台.跨网络.跨程序的语言的数据描述方式,使用XML可以方便地实现数据交换.系统配置.内容管理等常见功能. ...
- 2018SDIBT_国庆个人第七场
A - Complete the Word(暴力) Description ZS the Coder loves to read the dictionary. He thinks that a wo ...
- ArcGIS自定义工具箱-清空工作空间
ArcGIS自定义工具箱-清空工作空间 联系方式:谢老师,135-4855-4328,xiexiaokui#qq.com 目的:删除工作空间里的要素类,栅格和独立表 使用方法: 例如"C:\ ...
- HashMap负载因子为什么是0.75
待写 HashMap负载因子为什么是0.75?HashMap有一个初始容量大小,默认是16static final int DEAFULT_INITIAL_CAPACITY = 1 << ...
- Shapley值的一个应用
看书有这样一个问题,某互联网公司今天需要加班,需要编写一个500行的程序代码,产品经理找了三个程序员来完成.按照完成量发奖金:1号普通程序员独立能写100行,2号大神程序员独立能写125行,3号美女程 ...
- Fiddler响应post的请求 request body
是想传json格式的数据,请求头可以这样写:(应该先勾选 post,然后写上正确滴请求地址) User-Agent: Fiddler Host: localhost:1455 <span sty ...
- python学习笔记(三)- 字典、集合
字典:key-value形式 1)取数据方便 #字典里面没有重复的key 2)查询速度快 #字典是无序的 一.定义一个字典 infos = { 'name':'王小明', 'sex':'male' ...
- linux 下将tomcat注册成服务并开机启动
一.将startup.sh和shutdown.sh新建软连接到/usr/bin ln -s /usr/local/apache-tomcat-8.5.38/bin/startup.sh /usr/bi ...
- 用rekit创建react项目
第一步 先进入github.com 然后搜索rekit 往下滑 1 . 先全局安装 npm install -g rekit 2 . 进入自己想要创建项目文件的目录输入 rekit create / ...