这里,我们再说说radio、checkbox、select的验证方式。

1、用新版的写法进行验证。

<!DOCTYPE html>
<html>
<head>
<script src="js/jquery.js"></script>
<script src="js/jquery.validate.js"></script>
<script>
$().ready(function() {
$("#registerForm").validate();
});
</script>
<style>
#registerForm label.error {
margin-left: 10px;
color: red;
}
</style>
</head>
<body>
<form id="registerForm" method="get" action="">
<fieldset>
<!-- radio的验证 -->
性别 <span><br/>
男<input type="radio" id="gender_male" value="m" name="gender" required="true" data-msg-required="性别不能为空"/><br />
女<input type="radio" id="gender_female" value="f" name="gender" />
</span>
<!-- checkbox的验证 -->
<br/>最少选择两项 <span><br />
选项1<input type="checkbox" id="check_1" value="1" name="checkGroup" required="true" data-msg-required="必须选择" minlength=2 data-msg-minlength="至少选择2项"/><br />
选项2<input type="checkbox" id="check_2" value="2" name="checkGroup" /><br />
选项3<input type="checkbox" id="check_3" value="3" name="checkGroup" /><br />
</span>
<!-- select的验证 -->
<br/>下拉框 <span><br />
<select id="selectbox" name="selectbox" required="true" data-msg-required="必须选择">
<option value=""></option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
</span>
<p>
<input type="submit" value="提交">
</p>
</fieldset>
</form>
</body>
</html>

jv4-1.html

这种写法要注意一点,对于同一组的标签加验证规则,只能加在第一个标签里。例如性别那个标签组,规则  required="true" data-msg-required="性别不能为空"  只能放在第一个type等于radio的input里(也就是男后面的那个input),如果把验证规则放在后一个标签是无法正常验证的。

2、通过JavaScript自定义规则

<!DOCTYPE html>
<html>
<head>
<script src="js/jquery.js"></script>
<script src="js/jquery.validate.js"></script>
<script>
$().ready(function() {
$("#registerForm").validate({
rules : {
gender : {
required : true
},
checkGroup : {
required : true,
minlength:2
},
selectbox : {
required : true
}
},
messages : {
gender : {
required : '性别不能为空'
},
checkGroup : {
required : '必须选择',
minlength:'至少选择{0}项'
},
selectbox : {
required : '必须选择'
}
}
});
});
</script>
<style>
#registerForm label.error {
margin-left: 10px;
color: red;
}
</style>
</head>
<body>
<form id="registerForm" method="get" action="">
<fieldset>
<!-- radio的验证 -->
性别 <span><br/>
男<input type="radio" id="gender_male" value="m" name="gender"/><br />
女<input type="radio" id="gender_female" value="f" name="gender" />
</span>
<!-- checkbox的验证 -->
<br/>最少选择两项 <span><br />
选项1<input type="checkbox" id="check_1" value="1" name="checkGroup" /><br />
选项2<input type="checkbox" id="check_2" value="2" name="checkGroup" /><br />
选项3<input type="checkbox" id="check_3" value="3" name="checkGroup" /><br />
</span>
<!-- select的验证 -->
<br/>下拉框 <span><br />
<select id="selectbox" name="selectbox">
<option value=""></option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
</span>
<p>
<input type="submit" value="提交">
</p>
</fieldset>
</form>
</body>
</html>

jv4-2.html

在前面,我提到过自定义规则里rules和messages里的key用的是标签的name属性值,当时我也疑惑,为什么不直接用ID。刚才的代码,已经说明了原因。如果用的是ID,那么对于radio、checkbox这种通过name属性的值进行分组的标签,那可就没法进行验证了。

当然,如果你想让验证规则可以重用,那你也可以把它单独抽取出来,保存在一个JS文件里,然后在需要的页面引入。

接下来,说说提示语句的位置问题吧,也许你不想让提示语句显示在那个位置,那么没关系。

提示语句的位置是允许我们自定义的,十分的灵活。

<!DOCTYPE html>
<html>
<head>
<script src="js/jquery.js"></script>
<script src="js/jquery.validate.js"></script>
<script>
$().ready(function() {
$("#registerForm").validate({
rules : {
gender : {
required : true
},
checkGroup : {
required : true,
minlength:2
},
selectbox : {
required : true
}
},
messages : {
gender : {
required : '性别不能为空'
},
checkGroup : {
required : '必须选择',
minlength:'至少选择{0}项'
},
selectbox : {
required : '必须选择'
}
},
errorPlacement: function(error, element) {
if ( element.is("input[type=radio][name='gender']") )//通过选择器来判断
error.appendTo($("#eradio")); //通过选择器来查找指定元素
else if ( element.is(":checkbox") ) //这里有各种各样的查找方式,只要是满足语法的,都可以。
error.appendTo ( $("#echeckbox")); //完全可以满足你的任意位置的需求。
else
error.appendTo( $("#eother"));
}
});
});
</script>
<style>
#registerForm label.error {
margin-left: 10px;
color: red;
}
</style>
</head>
<body>
<form id="registerForm" method="get" action="">
<label id="eradio">单选提示信息:</label><br/>
<label id="echeckbox">多选提示信息:</label><br/>
<label id="eother">其他提示信息:</label><br/>
<fieldset>
<!-- radio的验证 -->
性别 <span><br/>
男<input type="radio" id="gender_male" value="m" name="gender"/><br />
女<input type="radio" id="gender_female" value="f" name="gender" />
</span>
<!-- checkbox的验证 -->
<br/>最少选择两项 <span><br />
选项1<input type="checkbox" id="check_1" value="1" name="checkGroup" /><br />
选项2<input type="checkbox" id="check_2" value="2" name="checkGroup" /><br />
选项3<input type="checkbox" id="check_3" value="3" name="checkGroup" /><br />
</span>
<!-- select的验证 -->
<br/>下拉框 <span><br />
<select id="selectbox" name="selectbox">
<option value=""></option>
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
</select>
</span>
<p>
<input type="submit" value="提交">
</p>
</fieldset>
</form>
</body>
</html>

jv4-3.html

对于提示语句的位置,就不说太多了,因为一般使用默认的位置也就行了。

只要你善用选择器,那个位置真的是任意定。

jQuery Validate(三)的更多相关文章

  1. jquery.validate+jquery.form提交的三种方式

    原文:http://www.cnblogs.com/datoubaba/archive/2012/06/06/2538873.html jquery.validate+jquery.form提交的三种 ...

  2. jQuery Validate 表单验证 — 用户注册简单应用

    相信很多coder在表单验证这块都是自己写验证规则的,今天我们用jQuery Validate这款前端验证利器来写一个简单的应用. 可以先把我写的这个小demo运行试下,先睹为快.猛戳链接--> ...

  3. jquery validate表单验证插件-推荐

    1 表单验证的准备工作 在开启长篇大论之前,首先将表单验证的效果展示给大家.     1.点击表单项,显示帮助提示 2.鼠标离开表单项时,开始校验元素  3.鼠标离开后的正确.错误提示及鼠标移入时的帮 ...

  4. 表单验证插件之jquery.validate.js

    提到表单验证的插件,第一个想到的就是jquery.validate.js,所以小生想在这里稍微详细地说一下这款插件的具体使用方法,便于理解,我直接附上整段demo的代码(没怎么调样式,主要是看js): ...

  5. jQuery Validate验证框架详解

    转自:http://www.cnblogs.com/linjiqin/p/3431835.html jQuery校验官网地址:http://bassistance.de/jquery-plugins/ ...

  6. 利用jquery.validate以及bootstrap的tooltip开发气泡式的表单校验组件

    表单校验是页面开发中非常常见的一类需求,相信每个前端开发人员都有这方面的经验.网上有很多成熟的表单校验框架,虽然按照它们默认的设计,用起来没有多大的问题,但是在实际工作中,表单校验有可能有比较复杂的个 ...

  7. jQuery验证控件jquery.validate.js使用说明

    官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation jQuery plugin: Validation 使用说明 转载 ...

  8. jquery.validate.js插件使用

    jQuery验证控件jquery.validate.js使用说明+中文API 官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-valid ...

  9. jquery.validate.js表单验证

    一.用前必备官方网站:http://bassistance.de/jquery-plugins/jquery-plugin-validation/ API: http://jquery.bassist ...

随机推荐

  1. WML标签速查手册 wap标签

    原文发布时间为:2010-08-19 -- 来源于本人的百度文章 [由搬家工具导入] WML标签速查手册(转)比较方便便于速查   结构相关标签 语法及属性 <wml> <wml x ...

  2. 线程间操作无效: 从不是创建控件“textBox4”的线程访问它

    原文发布时间为:2009-03-30 -- 来源于本人的百度文章 [由搬家工具导入] public long str1, str2, str3, str4, str5, sum=0,sum1=0; p ...

  3. 从数据库的表导出到Excel表格中【让客户端下载的Excel】

    原文发布时间为:2008-10-11 -- 来源于本人的百度文章 [由搬家工具导入] 这个例子是从gridview中导出到Excel,可以举一反三,可以直接从数据库中取值放在DataSet中,然后再从 ...

  4. Codeforces Round #441 Div. 2 A B C D

    题目链接 A. Trip for Meal 题意 三个点之间两两有路径,分别长为\(a,b,c\),现在从第一个点出发,走\(n-1\)条边,问总路径最小值. 思路 记起始点相邻的边为\(a,b\), ...

  5. 《Linux命令行与shell脚本编程大全 第3版》Linux命令行---1

    以下为阅读<Linux命令行与shell脚本编程大全 第3版>的读书笔记,为了方便记录,特地与书的内容保持同步,特意做成一节一次随笔,特记录如下: <Linux命令行与shell脚本 ...

  6. CocoaPods Setting up CocoaPods master repo无反应时的处理

    Setting up CocoaPods master repo,半天没有任何反应.原因无他,因为那堵墙阻挡了cocoapods.org...gitcafe和oschina都是国内的服务器,可以用它们 ...

  7. mysql5.7 mysql库下面的user表没有password字段无法修改密码

    如题所述,mysql5.7  mysql库下面的user表没有password字段无法修改密码, 5.7版本已经不再使用password来作为密码的字段了  而改成了authentication_st ...

  8. LeetCode OJ-- Insertion Sort List **

    https://oj.leetcode.com/problems/insertion-sort-list/ 链表实现插入排序 首先插入排序是指: a b c d e g m 对b也就是第二个位置选做元 ...

  9. java gc --- 四种引用

    古龙有<七种武器>,java里有四种引用. 下文主要是对 <understanding-weak-references>这一博文的重点进行翻译 强引用,strong refer ...

  10. IntelliJ IDEA安装MongoDB的的数据操作插件

    说明:只能说效果一般,没有Robo 3T那么好用. 参考: https://intellij-support.jetbrains.com/hc/en-us/community/posts/206635 ...