mvalidator手机端校验
官网地址:https://github.com/efri-yang/mobileValidate#%E5%8F%82%E6%95%B0
使用方法:
html如下:
<li class="li"><label class="label">车牌号:</label><span class="required"><input type="text" class="field-text input" id="carNumber" name="carNumber" belong="roCar" data-required="true" data-descriptions="carNumber" data-describedby="carNumber-description" data-conditional="digit" data-max="8"></span>
<div id="carNumber-description"></div>
</li>
<li class="li"><label class="label">制造厂商:</label><span class="required"><input type="text" class="field-text input" id="manufacturer" data-required="true" data-descriptions="manufacturer" data-describedby="manufacturer-description"></span>
<div id="manufacturer-description"></div>
</li>
<li class="li"><label class="label">车辆型号:</label><span class="required"><input type="text" class="field-text input" id="carType" data-required="true" data-descriptions="carType" data-describedby="carType-description" ></span>
<div id="carType-description"></div>
</li>
<li class="li"><label class="label">出厂年份:</label><span><input data-role="number" data-digit="0" type="number" class="input" name="factoryYear" id="factoryYear" belong="roCar" data-max="4" data-descriptions="factoryYear" data-describedby="factoryYear-description" data-conditional="greaterNow"></span>
<div id="factoryYear-description"></div>
</li>
<li class="li"><label class="label">车架号码:</label><span><input type="text" class="input" name="frameNumber" id="frameNumber" belong="roCar" data-max="20" data-descriptions="frameNumber" data-describedby="frameNumber-description" data-conditional="digit"></span>
<div id="frameNumber-description"></div>
</li>
js如下:
//表单验证
var descriptions={
carNumber:{
required : '<div class="field-invalidmsg" style="color:red;">请输入车牌号</div>',
conditional : '<div class="field-invalidmsg" style="color:red;">车牌号必须小于8位</div>',
valid : ""
},
manufacturer:{
required : '<div class="field-invalidmsg" style="color:red;">请输入制造厂商</div>',
valid : ""
},
carType:{
required : '<div class="field-invalidmsg" style="color:red;">请输入车辆型号</div>',
valid : ""
},
frameNumber:{
conditional : '<div class="field-invalidmsg" style="color:red;">车架号码必须小于20位</div>',
valid : ""
},
customerName:{
conditional : '<div class="field-invalidmsg" style="color:red;">姓名必须小于20位</div>',
valid : ""
},
email:{
conditional : '<div class="field-invalidmsg" style="color:red;">email必须小于100位</div>',
valid : ""
},
phone:{
conditional : '<div class="field-invalidmsg" style="color:red;">手机号必须小于13位</div>',
valid : ""
},
textarea1:{
conditional : '<div class="field-invalidmsg" style="color:red;">备注必须小于200位</div>',
valid : ""
},
couponCode:{
conditional : '<div class="field-invalidmsg" style="color:red;">优惠券必须小于50位</div>',
valid : ""
},
roNumber:{
required : '<div class="field-invalidmsg" style="color:red;">请输入工单号</div>',
conditional : '<div class="field-invalidmsg" style="color:red;">工单号必须小于16位</div>',
valid : ""
},
appointInDate: {
conditional : '<div class="field-invalidmsg" style="color:red;">请输入预约进厂时间</div>',
valid : ""
},
inDate:{
required : '<div class="field-invalidmsg" style="color:red;">请输进厂时间</div>',
valid : ""
},
factoryYear: {
conditional : '<div class="field-invalidmsg" style="color:red;">出厂年份要大于1900小于今年</div>',
valid : ""
},
textarea2:{
conditional : '<div class="field-invalidmsg" style="color:red;">备注必须小于200位</div>',
valid : ""
}
};
$("#form").validate({
conditional:{
isappointed:function(val){
var flag;
return (isAppointed==true&&val=="") ? false :true;
},
greaterNow:function(val){
if(val){
return ((val<=new Date().getFullYear())&&(val>=1900)||val=="0")?true:false;
}
else return true;
},
digit:function(val,options){
var digit=$(this).attr("data-max");
var length=val.length;
return (length<=digit)?true:false;
}
},
valid: savefunc,
descriptions:descriptions
});
})
重点:
html配置:
data-required="true" data-descriptions="carNumber" data-describedby="carNumber-description" data-conditional="digit"
js配置:
descriptions
conditional
valid
渲染后的效果如下:

在自己的使用过程中由于插件受到自己的框架影响报错,我自己修改了一下又能用了
$.fn.mvalidateDestroy=function(){
var $form=$(this),$fields,
dataValidate=$form.data(name);
if(typeof dataValidate!="object") {
if ($form.is('form') && $.isPlainObject(dataValidate) && typeof(dataValidate.options.namespace) == 'string') {
$fields = $form.removeData(name).find(allTypes);
$fields.off('.' + dataValidate.options.namespace);
}
}
return $form;
}
后来查了一下原因,是因为我用了sui组件,sui修改了zepto.js的data方法,使之能够存储对象,只需要再判断一次datavalidate是不是一个对象即可解决这个报错问题
mvalidator手机端校验的更多相关文章
- 写了个TP5下PHP和手机端通信的API接口校验
写了个PHP和手机端通信的API接口校验 直接发函数吧 public function _initialize() { //定义密码和盐 $password="123456"; $ ...
- C#校验手机端或客户端
以下代码用来检查,客户端是手机端还是PC端 string strUserAgent = Request.UserAgent.ToString().ToLower(); bool isMobile = ...
- 手机端的表单验证和PC端的不同
1.手机端:由于页面小的局限性,表单验证从上到下依次进行,如果上一个验证不通过,则给出错误提示,代码中return回去,不必进行下一个的校验: 2.PC端:页面范围大,一般是在表单的后面或者下面,提示 ...
- 使用localResizeIMG3+WebAPI实现手机端图片上传
前言 惯例~惯例~昨天发表的使用OWIN作为WebAPI的宿主..嗯..有很多人问..是不是缺少了什么 - - 好吧,如果你要把OWIN寄宿在其他的地方...代码如下: namespace Conso ...
- 《JS实现复制内容到剪贴板功能,可兼容所有PC浏览器,不兼容手机端》
前记:本来原生的JS是有提供一个函数来实现这个功能(window.clipboardData),但是很遗憾,这个函数仅仅支持IE和FF浏览器,所以基本用处不大.下边介绍的是一个第三方插件库(ZeroC ...
- 【极品代码】一般人我不告诉他,手机端h5播放时不自动全屏代码
已测适用于ios,某些安卓手机微信下播放视频会出现播放器控件(这个实在是无力吐槽噢,因为之前还遇到过微信播放完视频后竟然无法退出全屏出现广告的情况,只有播放完后刷新页面并且要放到框架页里才能屏蔽微信视 ...
- 判断是pc端还是手机端,并跳转到相应页面
<!-- 判断浏览器是否为手机端 --> <script> // class ! function(navigator) { var user ...
- h5手机端下拉选择城市
<!doctype html><html> <head> <meta http-equiv="Content-Type& ...
- PHP项目实现手机端和PC端的页面切换
目前访问页面的要切换成手机端和PC端,原理是通过对设备作出判断,显示不同的功能和页面. 如果手机端和PC端的功能结构不相同,一般会写两套系统,一套适用于PC端,一套适用于手机端. 如果功能相同,则只需 ...
随机推荐
- android 项目更改包名的方法
本文章全文转载: http://www.2cto.com/kf/201304/206747.html 1.在项目上右键,选择android tools->rename application p ...
- React实例----一个表单验证比较复杂的页面
前言:这阵子看了两本CSS的书~对于CSS层叠,定位,继承等机制基本上都了解了,就想着自己写几个页面~正好自己就写了写CSS样式,然后用React渲染出来~ 闲话不多说,简单说一说这个页面,希望能对大 ...
- ImageSpan图片不能居中的问题
点击下载:MyImageSpan.txt 使用ImageSpan的童鞋应该都会遇到这样一个困惑,图片不能居中显示,ImageSpan中只有ImageSpan.ALIGN_BASELINE与ImageS ...
- JS事件绑定深入
W3C很好地解决了覆盖问题.相同函数屏蔽的问题.this传递问题.添加额外方法不被覆盖等问题. 但是IE8之前的版本并不支持,IE9已完全支持了. IE和W3C在事件绑定上存在很多差异,我们以冒泡和捕 ...
- fiddler介绍
先看fiddler 的使用界面和各模块的功能介绍 1请求列表:请求列表中包含了许多信息,从左至右依次为,#(序列号),Result(结果状态码),Prottocol(请求的协议),Host(请求的主机 ...
- iOS仿微博客户端一条微博的布局
前言 做一个微博客户端的第三方是自学的第一个实践的项目,自从从事iOS工作之后,就把这个项目给搁置了.趁现在过年回来有些空闲时间,再次修改(总觉得项目就是不停地修改).并且记录一点东西,以后可再回头看 ...
- 每天一个Linux命令(16)--which命令
把昨天的,留给昨天:今日,你将重新开始. 好的,在第一个阶段我们学习了 文件目录的操作命令: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ls cd pwd mkdir ...
- 上传图片,多图上传,预览功能,js原生无依赖
最近很好奇前端的文件上传功能,因为公司要求做一个支持图片预览的图片上传插件,所以自己搜了很多相关的插件,虽然功能很多,但有些地方不能根据公司的想法去修改,而且需要依赖jQuery或Bootstrap库 ...
- github学习(二)
Git学习(一) 学习github一定要学会git,否则在后续的github运用中会出现很多问题. 1.安装Git: Mac自带Git,Windows需要自己安装. 2.配置git: 配置user.n ...
- 基于nodejs模拟浏览器post请求爬取json数据
今天想爬取某网站的后台传来的数据,中间遇到了很多阻碍,花了2个小时才请求到数据,所以我在此总结了一些经验. 首先,放上我所爬取的请求地址http://api.chuchujie.com/api/?v= ...