js数据校验插件
//数据校验
/**
*{type:"类型",notEmpty:true,regxp: reg,MaxLength: number,MinLength number,message: '错误提示信息'}
* 校验类型 type:phone(手机号)/mail(邮箱)/mount(整数)/money(金额)/passwd(密码)/reg(正则验证)/notNull(不能为空) 必填
* 是否可为空 Emptable: true(true可为空,false不能为空;默认为false)
* 正则匹配 regexp( 内容与该正则进行验证,type需要为reg,否则无效 message 错误提示信息 ) type为reg时必填
* 失败提示内容message: String type为reg/notNull时必填
* 例子:{type:phone,notEmpty:true}
* @constructor
*/
var TestData = function () {
var me = this;
//全体校验方法
me.TestAll = function(){
var InputList = $("[validata]");
var data = '';
var result = true;
for(var i=0;i<InputList.length;i++){
data = InputList[i].getAttribute("validata");
if(data){
data = me.strToJson(data);
if(!me.ifNull(data.type)){
var value = InputList[i].value;
if(!me.TestByType(data,value)){
return false;
}
}else{
console.log("type不能为空")
}
}
}
return result;
};
//根据type进行验证
me.TestByType = function (data,value) {
if(data.type == 'phone'){
if(value){
return me.isPhone(value);
}else{
return me.isEmpty('',data.Emptable,'手机不能为空')
}
}else if(data.type == 'mail'){
if(value){
return me.isMail(value);
}else{
return me.isEmpty('',data.Emptable,'邮箱不能为空')
} }else if(data.type == 'passwd'){
if(value){
return me.isPwd(value);
}else{
return me.isEmpty('',data.Emptable,'密码不能为空')
} }else if(data.type == 'reg'){
if(me.ifNull(data.regex)){
console.log('参数缺少正则表达式')
return false;
}else if(me.ifNull(data.message)){
console.log('参数message作为提示信息')
return false;
}
return me.regTset(value,data.regex,data.message) }else if(data.type == 'mount'){
if(value){
return me.isNumber(value); }else{
return me.isEmpty('',data.Emptable,'数量不能为空')
}
}else if(data.type == 'money'){
if(value){
return me.isMoney(value);
}else{
return me.isEmpty('',data.Emptable,'金额不能为空')
}
}else if(data.type == 'notNull'){
return me.isEmpty(value,data.Emptable,data.message)
}
}
//正则验证
me.regTset = function (o,regex,message) {
var reg = regex;
if(o){
if(!reg.test(o)) {
wrap.alert(message);//验证不通过提示
return false;
}
}else{
return me.isEmpty('',false,message);
} return true;
}
//密码校验
me.isPwd = function (o) {
return me.regTset(o,/^[0-9a-zA-Z]+$/,'密码格式错误');
}
//手机号校验
me.isPhone = function (o) {
// var phone_reg = /^(((13[0-9]{1})|(15[0-9]{1})|(18[0-9]{1}))+\d{8})$/;
var phone_reg = /^(1+\d{10})$/;
return me.regTset(o,phone_reg,'请输入有效的手机号码');
}
//邮箱校验
me.isMail = function (o) {
var mail_reg = /^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/;
return me.regTset(o,mail_reg,'请输入有效的邮箱');
}
//金额校验
me.isMoney = function (o) {
var money_reg = /^([1-9][\d]{0,7}|0)(\.[\d]{1,2})?$/;
return me.regTset(o,money_reg,'请输入有效的金额');
}
//数量校验
me.isNumber = function (o) {
var number_reg = /^[1-9]\d*$/;
return me.regTset(o,number_reg,'请输入正确的数量');
}
//是否允许为空 允许为空 返回true 不允许为空 且为空,返回false 打印错误信息
me.isEmpty = function(o,emptable,message) {
if(emptable){
return true;
}else{
if(o == undefined || o == "" || o == null){
wrap.alert(message);
return false;
}
return true;
} }
//是否为null
me.ifNull = function (o) {
return o == undefined || o == "" || o == null
}
//string转json
me.strToJson = function (str){
var json = eval('(' + str + ')');
return json;
}
}
js数据校验插件的更多相关文章
- 开源后端数据校验插件Validate.Net,类似Validate.js
介绍 Validate.Net将Validate.js移植到.Net平台,可以更方便.更快捷的校验实体内属性值是否合法.内置多种常规数据校验规则(校验必填.校验字符串长度区间.校验最大最小值.校验值区 ...
- HTML JS 数据校验
用到了html字符串校验,这里记录一下. <html> <head> <script type="text/javascript"> funct ...
- jQuery Validate 表单验证插件----利用jquery.metadata.js将校验规则直接写在class属性里面并定义错误信息的提示
一.下载依赖包 网盘下载:https://yunpan.cn/cryvgGGAQ3DSW 访问密码 f224 二. 添加一个另外一个插件jquery.metadata.js 并把校验规则写在控件里面 ...
- Atom 编辑器安装 linter-eslint 插件,并配置使其支持 vue 文件中的 js 格式校验
安装方式有如下几种. 1.最常用的安装方式. # 进入atom插件文件夹 cd ~/.atom/packages/ # git clone 插件源文件 git clone https://github ...
- springboot使用validation 插件做数据校验
不多说废话. 首先,我们需要在入参实体对象中,使用注解,控制 @Datapublic class UpdateShufflingRequest { private String shuffling_l ...
- JavaScript的案例(数据校验,js轮播图,页面定时弹窗)
1.数据校验 步骤 1.确定事件(onsubmit)并绑定一个函数 2.书写这个函数,获取数据,并绑定id 3. ...
- Knockout.js 数据验证之插件版和无插件版
本文我们将介绍使用 Knockout.js 实现一些基本的数据验证.就如我们在标题里提到的,我们会使用两种方法来创建数据验证方法. 使用自定义方法,不需要任何插件 最简单的方法是使用已有的插件 如果你 ...
- JS常用数据校验集合(adding)
常用数据校验集合 var _validator = { MAIL_REGEX: /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,; ...
- 【JAVAWEB学习笔记】28_jqueryAjax:json数据结构、jquery的ajax操作和表单校验插件
Ajax-jqueryAjax 今天内容: 1.json数据结构(重点) 2.jquery的ajax操作(重点) 3.jquery的插件使用 一.json数据结构 1.什么是json JSON(J ...
随机推荐
- 把axios封装为vue插件使用
前言 自从Vue2.0推荐大家使用 axios 开始,axios 被越来越多的人所了解.使用axios发起一个请求对大家来说是比较简单的事情,但是axios没有进行封装复用,项目越来越大,引起的代码冗 ...
- python基础面试常见题
1.为什么学习Python? Python是目前市面上,我个人认为是最简洁.最优雅.最有前途.最全能的编程语言,没有之一. 2.通过什么途径学习的Python? 通过自学,包括网上查看一些视频,购买一 ...
- Django(十一)请求生命周期之CBV与FBV
https://www.cnblogs.com/yuanchenqi/articles/8715364.html FBV FBV(function base views) 就是在视图里使用函数处理请求 ...
- R语言:提取路径中的文件名字符串(basename函数)
假设存在路径C:/coverage/Homo_sapiens.sort.add_exon1_coverage.txt,欲提取Homo_sapiens.sort.add_exon1_coverage.t ...
- QT槽函数处理线程
今天用到QTcpSocket的时候,由于客户端发起请求在一个线程里,当readyRead的信号发出后接收的槽函数是否还会在该线程里处理? 现在看来其实是交给主线程处理的,那么我要实现在线程里处理怎么实 ...
- js弹出层
js弹出层 1.div附近显示 <div id="message"></div> $().delay().hide(); 2.遮罩层 表单提交后遮住页面,等 ...
- qml: 自定义滚动条;
注: 该博文为原创博文,转载请注明,摘用请随意: qml自带的滚动条不太好用: 首先,利用canvas绘制滚动条两端的箭头: import QtQuick 2.0 Canvas { width: 2 ...
- 三台机器之间root用户ssh互信配置
三台机器之间root用户ssh互信配置 (1)在所有的主机上执行:ssh-keygen -t rsa # 在每台都需要操作,一路回车 (2)将所有机子上公钥(id_rsa.pub)导到一个主机的/ro ...
- Jvm threaddump,heapdump的分析及问题定位
1 一.Thread Dump介绍 1.1 1.1什么是Thread Dump? 1.2 1.2 Thread Dump特点 1.3 1.3 Thread Dump 能诊断的问题 1.4 1.4如何抓 ...
- java io系列07之 FileInputStream和FileOutputStream
本章介绍FileInputStream 和 FileOutputStream 转载请注明出处:http://www.cnblogs.com/skywang12345/p/io_07.html File ...