jQuery验证框架使用例子

本文通过一个具体的实例展示了如何使用jQuery的Validator插件进行表单验证。包括引入必要的JS文件、定义验证规则及错误提示信息等步骤。

jQuery的validator框架用起来挺舒服的,方便而且扩展也挺方便的。比起之前写的纯js验证看起来也优雅多了。以下是个例子,也是仿着别人的来做的,大同小异。

首先引入的js文件如下:

<script type="text/javascript" src="js/jquery.form.js"></script>
<script type="text/javascript" src="js/jquery.validate.js"></script>
<script type="text/javascript" src="js/jquery.js"></script>

 验证信息所采用的样式如下:

<style type="text/css">  
	label.errorMsg {border:1px solid red;PADDING-LEFT: 25px;color: red;vertical-align: middle;background:url('${root}/images/gif/register/error.png') no-repeat;background-position: left}   
	input.errorMsg { border: 1px dotted red; background:url('images/gif/register/invalid_line.gif') repeat-x 100px bottom;}   
	 label.valid { border:0px;background:url('images/gif/register/correct.png') no-repeat 0 -1px;}   
	input.focus { border: 2px solid green; }   
	ul li{ display: block;}   
 </style>

 

html代码

<form styleId="regFormid" method="post" enctype="multipart/form-data" action="/reg.do?method=register"> 
	<table width="700" border="0" cellpadding="0" cellspacing="0">
		<tr>
			<tr>
				<td height="35" align="left" >
					<span>账号</span>
					<span><input id="regname" type="text" name="regname"/></span>
					<span></span>
				</td>
			</tr>
			<tr>
				<td height="35" align="left" >
					<span>昵称</span>
					<span><input id="nickname" type="text" name="nickname"/></span>
					<span></span>
				</td>
			</tr>
			<tr>
				<td height="35">
					<span>密码</span>
					<span><input id="regpwd" type="password" name="regpwd"/></span>
					<span></span>	
				</td>
			</tr>
			<tr>
				<td height="35">
					<span>确认密码</span>
					<span><input type="password" id="reregpwd" name="reregpwd"/></span>
					<span></span>
				</td>
			</tr>
			<tr>
				<td height="35">
					<span>邮箱</span>
					<span><input type="text" id="email" name="email"/></span>
					<span></span>	
				</td>
			</tr>
			<tr>
				<td height="35">
					<span>确认邮箱</span>
					<span><input type="text" id="remail" name="remail"/></span>
					<span></span>	
				/td>
			</tr>
			<tr>
				<td height="35">
					<span>性别</span>
					<span>
					   <input id="genderid1" type="radio" name="gender" value="1"/>男
					   <input id="genderid0" type="radio" name="gender" value="0"/>女
					</span>
					<span></span>		
				</td>
			</tr>
			<tr>
				<td height="70px">
					<span>头像</span>
					<span><input id="headpic" type="file" name="headpic" /></span><span></span>
				</td>
			</tr>
			<tr>
				<td height="35">
					<span>验证码</span>
					<span><input id="verify" type="text" name="verify" size="6"/>
					<a href="javascript:reloadVerifyCode();">
					<img height="24" align="absmiddle" width="56" id="safecode" src="/RandomCodeCtrl"/>
					</a>
					</span>
					<span></span>
				</td>
			</tr>
			<tr>
				<td>
					<input type="submit" value="submit" />
				</td>
			</tr>
							
</form>

 js代码如下:

$(function() {
	$("#regFormid").validate({
		errorClass: "errorMsg", 
		onkeyup: false,
		rules: {
			regname: {
				required: true,
				byteRangeLength: [3,10],
				userName:true,
				isForbidden:true,
				remote: "checkName.jsp?flag=login"
			},
			nickname: {
				required: true,
				byteRangeLength: [3,10],
				userName:true,
				isForbidden:true,
				remote: "checkName.jsp?flag=nick"
			},
			regpwd: {
				required: true,
				rangelength: [6,18]
			},
			reregpwd: {
				required: true,
				rangelength: [6,18],
				equalTo: "#regpwd"
			},
			email: {
				required: true,
				email: true,
				remote: checkEmail.jsp"
			},
			remail: {
				required: true,
				equalTo: "#email",
				email: true,
				remote: "checkEmail.jsp?flag=remail"
			},
			gender: {   
                required: true  
            }, 
			headpic: {   
                accept: "jpg,jpeg,gif"  
            },   
			verify: {
				required: true,
				remote: "checkVerifyCode.jsp"
			},
		},
		messages: {
			regname: {
				required: "账号为必填项!",
				byteRangeLength: $.format("请确保账号在{0}-{1}个字符之间(一个中文字算2个字符)!"),
				isForbidden:$.format("不能输入保留字,请重新输入!"),
				remote:"账号已经被占用!"
				//remote: $.format("{0}已经被占用")"请确保输入的值在3-10个字符之间(一个中文字算2个字符)"
			},
			nickname: {
				required: "昵称为必填项!",
				byteRangeLength: $.format("请确保昵称在{0}-{1}个字符之间(一个中文字算2个字符)!"),
				isForbidden:$.format("不能输入保留字,请重新输入!"),
				remote:"昵称已经被占用!"
				//remote: $.format("{0}已经被占用")
			},
			regpwd: {
				required: "密码为必填项!",
				rangelength: $.format("密码要在{0}-{1}个字符之间!")
			},
			reregpwd: {
				required: "确认密码为必填项!",
				rangelength: $.format("确认密码要在{0}-{1}个字符之间!"),
				equalTo: "确认密码必须要和密码一致!"
			},
			email: {
				required: "邮箱为必填项!",
				email: "请正确输入邮箱格式(例如 myemail@163.com)",
				remote: "您输入的邮箱已被注册,请重新输入!"
			},
			remail: {
				required: "确认邮箱为必填项!",
				equalTo: "确认邮箱必须和邮箱一致!",
				email: "请正确输入邮箱格式(例如 myemail@163.com)",
				remote: "您输入的邮箱已被注册,请重新输入!"
			},
			gender: {
				required: "请选择性别!"
			},
			headpic: {
				accept: "图片格式必须为jpg,jpeg或gif!"
			},
			verify: {
				required: "验证码为必填项!",
				remote: "验证码不正确!"
			}},
		errorPlacement: function(error, element) {  //验证消息放置的地方   
            error.appendTo( element.parent("span").next("span") );   
        },   
        highlight: function(element, errorClass) {  //针对验证的表单设置高亮   
            $(element).addClass(errorClass);   
        },   
        success: function(label) {     
             label.html("&nbsp;").addClass("valid");     
        } 
        
	});
});

 还有些Ajax调用,这里就不一一列出,很简单,只要在相应的jsp的输出流中输出true或者false即可

同步定位与地图构建(SLAM)技术为移动机器人自主载具在未知空间中的导航提供了核心支撑。借助该技术,机器人能够在探索过程中实时构建环境地图并确定自身位置。典型的SLAM流程涵盖传感器数据采集、数据处理、状态估计及地图生成等环节,其核心挑战在于有效处理定位与环境建模中的各类不确定性。 Matlab作为工程计算与数据可视化领域广泛应用的数学软件,具备丰富的内置函数与专用工具箱,尤其适用于算法开发与仿真验证。在SLAM研究方面,Matlab可用于模拟传感器输出、实现定位建图算法,并进行系统性能评估。其仿真环境能显著降低实验成本,加速算法开发与验证周期。 本次“SLAM-基于Matlab的同步定位与建图仿真实践项目”通过Matlab平台完整再现了SLAM的关键流程,包括数据采集、滤波估计、特征提取、数据关联与地图更新等核心模块。该项目不仅呈现了SLAM技术的实际应用场景,更为机器人导航与自主移动领域的研究人员提供了系统的实践参考。 项目涉及的核心技术要点主要包括:传感器模型(如激光雷达与视觉传感器)的建立与应用、特征匹配与数据关联方法、滤波器设计(如扩展卡尔曼滤波与粒子滤波)、图优化框架(如GTSAM与Ceres Solver)以及路径规划与避障策略。通过项目实践,参与者可深入掌握SLAM算法的实现原理,并提升相关算法的设计与调试能力。 该项目同时注重理论向工程实践的转化,为机器人技术领域的学习者提供了宝贵的实操经验。Matlab仿真环境将复杂的技术问题可视化与可操作化,显著降低了学习门槛,提升了学习效率与质量。 实践过程中,学习者将直面SLAM技术在实际应用中遇到的典型问题,包括传感器误差补偿、动态环境下的建图定位挑战以及计算资源优化等。这些问题的解决对推动SLAM技术的产业化应用具有重要价值。 SLAM技术在工业自动化、服务机器人、自动驾驶及无人机等领域的应用前景广阔。掌握该项技术不仅有助于提升个人专业能力,也为相关行业的技术发展提供了重要支撑。随着技术进步与应用场景的持续拓展,SLAM技术的重要性将日益凸显。 本实践项目作为综合性学习资源,为机器人技术领域的专业人员提供了深入研习SLAM技术的实践平台。通过Matlab这一高效工具,参与者能够直观理解SLAM的实现过程,掌握关键算法,并将理论知识系统应用于实际工程问题的解决之中。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值