validate.js
前端的validate.js
/**
* Created by PanJiaChen on 16/11/18.
*/
/**
* @param {string} path
* @returns {Boolean}
*/
export function isExternal(path) {
return /^(https?:|mailto:|tel:)/.test(path)
}
/**
* @param {string} str
* @returns {Boolean}
*/
export function validUsername(str) {
const valid_map = ['admin', 'editor']
return valid_map.indexOf(str.trim()) >= 0
}
/**
* @param {string} url
* @returns {Boolean}
*/
export function validURL(url) {
const reg = /^(https?|ftp):\/\/([a-zA-Z0-9.-]+(:[a-zA-Z0-9.&%$-]+)*@)*((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9][0-9]?)(\.(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])){3}|([a-zA-Z0-9-]+\.)*[a-zA-Z0-9-]+\.(com|edu|gov|int|mil|net|org|biz|arpa|info|name|pro|aero|coop|museum|[a-zA-Z]{2}))(:[0-9]+)*(\/($|[a-zA-Z0-9.,?'\\+&%$#=~_-]+))*$/
return reg.test(url)
}
export function judgeRegionLevel(regionCode) {
const provinceRex = /^[1-9]\d0000000000$/
const cityRex = /^[1-9]\d((0[1-9])|([1-9]\d))00000000$/
const countyRex = /^[1-9]\d((0[1-9])|([1-9]\d))((0[1-9])|([1-9]\d))000000$/
const townRex = /^[1-9]\d((0[1-9])|([1-9]\d))((0[1-9])|([1-9]\d))((00[1-9])|(0[1-9]\d)|([1-9][1-9]\d))000$/
const communityRex = /^[1-9]\d((0[1-9])|([1-9]\d))((0[1-9])|([1-9]\d))((00[1-9])|(0[1-9]\d)|([1-9][1-9]\d))((00[1-9])|(0[1-9]\d)|([1-9][1-9]\d))$/
if (provinceRex.test(regionCode)) {
return 1
} else if (cityRex.test(regionCode)) {
return 2
} else if (countyRex.test(regionCode)) {
return 3
} else if (townRex.test(regionCode)) {
return 4
} else if (communityRex.test(regionCode)) {
return 5
} else {
return -1
}
}
/**
* @param {string} str
* @returns {Boolean}
*/
export function validLowerCase(str) {
const reg = /^[a-z]+$/
return reg.test(str)
}
/**
* 验证正整数
* @param str
* @returns {boolean}
*/
export function validPositiveInteger(str) {
const reg = /^[1-9]\d*$/
return reg.test(str)
}
/**
* 验证数字,带有小数的
* @param str
* @returns {boolean}
*/
export function validDigit(str) {
const reg = /(^[1-9]\d*(\.\d+)?$)|(^0(\.\d+)?$)/
return reg.test(str)
}
/**
* @param {string} str
* @returns {Boolean}
*/
export function validUpperCase(str) {
const reg = /^[A-Z]+$/
return reg.test(str)
}
/**
* @param {string} str
* @returns {Boolean}
*/
export function validAlphabets(str) {
const reg = /^[A-Za-z]+$/
return reg.test(str)
}
/**
* @param {string} email
* @returns {Boolean}
*/
export function validEmail(email) {
const reg = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/
return reg.test(email)
}
export function isvalidPhone(phone) {
const reg = /^1[3|4|5|7|8][0-9]\d{8}$/
return reg.test(phone)
}
export function isvalidFixPhone(phone) {
const reg = /^(\(\d{3,4}\)|\d{3,4}-|\s)?\d{7,14}$/
return reg.test(phone)
}
/**
* @param {string} str
* @returns {Boolean}
*/
export function isString(str) {
if (typeof str === 'string' || str instanceof String) {
return true
}
return false
}
/**
* @param {Array} arg
* @returns {Boolean}
*/
export function isArray(arg) {
if (typeof Array.isArray === 'undefined') {
return Object.prototype.toString.call(arg) === '[object Array]'
}
return Array.isArray(arg)
}
/**
* 是否合法IP地址
* @param rule
* @param value
* @param callback
*/
export function validateIP(rule, value, callback) {
if (value === '' || value === undefined || value == null) {
callback()
} else {
const reg = /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/
if ((!reg.test(value)) && value !== '') {
callback(new Error('请输入正确的IP地址'))
} else {
callback()
}
}
}
/* 是否手机号码或者固话*/
export function validatePhoneTwo(rule, value, callback) {
const reg = /^((0\d{2,3}-\d{7,8})|(1[34578]\d{9}))$/
if (value === '' || value === undefined || value == null) {
callback()
} else {
if ((!reg.test(value)) && value !== '') {
callback(new Error('请输入正确的电话号码或者固话号码'))
} else {
callback()
}
}
}
/* 是否固话*/
export function validateTelephone(rule, value, callback) {
const reg = /0\d{2}-\d{7,8}/
if (value === '' || value === undefined || value == null) {
callback()
} else {
if ((!reg.test(value)) && value !== '') {
callback(new Error('请输入正确的固话(格式:区号+号码,如010-1234567)'))
} else {
callback()
}
}
}
/* 是否手机号码*/
export function validatePhone(rule, value, callback) {
const reg = /^[1][3,4,5,7,8][0-9]{9}$/
if (value === '' || value === undefined || value == null) {
callback()
} else {
if ((!reg.test(value)) && value !== '') {
callback(new Error('请输入正确的电话号码'))
} else {
callback()
}
}
}
/* 是否身份证号码*/
export function validateIdNo(value) {
const reg = /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/
return reg.test(value)
}
export function checkPassWord(password) { // 密码必须包含数字和字母
var str = password
if (str == null || str.length < 8) {
return false
}
var reg = new RegExp(/^(?![^a-z]+$)(?!\D+$)/)
// var reg2 = new RegExp(/^(?![^A-Z]+$)(?!\D+$)/)
// if (reg2.test(str)) {
if (reg.test(str)) { return true }
// }
return false
}
/* 是否行政区划编码--省级*/
export function validateProvinceCode(value) {
const reg = /^[1-9]\d0000$/
return reg.test(value)
}
/* 是否行政区划编码--地市*/
export function validateCityCode(value) {
const reg = /^[1-9]\d((0[1-9])|([1-9]\d))00$/
return reg.test(value)
}
/* 是否行政区划编码--区县*/
export function validateAreaCode(value) {
const reg = /^[1-9]\d((0[1-9])|([1-9]\d))((0[1-9])|([1-9]\d))$/
return reg.test(value)
}
validate.js相关推荐
- jQuery验证控件jquery.validate.js使用说明+中文API
官网地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation jQuery plugin: Validation 使用说明 转载 ...
- jq.validate.js
首选必须是要下载滴,jq.validate.js表单效验方式. 建立form表单没得说 <form id="form"><p><label for=& ...
- jQuery.validate.js API
为什么80%的码农都做不了架构师?>>> jQuery.validate.js API 转载于:https://my.oschina.net/azheng/blog/10281
- jQuery表单校验jquery.validate.js的使用
jQuery是一个快速.简洁的js库,为网站的快速开发简化了HTML文档遍历,事件处理,动画,以及Ajax交互.使用jQuery将极大的提高编写javascript代码的效率, 让写出来的代码更加优雅 ...
- jquery.validate.js插件的使用方法
近期做项目.须要用到 jQuery.validate.js插件,于是记录一下工作中的一些经验,以便日后学习. [样例例如以下] 1.前台页面 <form id="form1" ...
- ASP.NETmvc常用JQUERY收藏【jquery.form.js结合jquery.validate.js】
虽然jquery.form.js可以通过自定义验证方式实现个性化的验证,不过我们大量使用的还不是一个红星(*) 在jquery.form.js下使用jquery.validate.js就可以简简单单的 ...
- 当同时使用bootstrap-datepicker.js和jquery.validate.js这两款插件,至少要选择两次时间,才能验证成功的问题...
当用 bootstrap-datepicker.js 这个插件选择时间,再用jquery.validate.js进行验证,当时间不为空时则验证通过.可能由于在时间插件弹出来时,input框的值发生改变 ...
- 修改 jquery.validate.js 支持非form标签
尝试使用markdown来写一篇blog,啦啦啦 源代码传送门:github 在特殊情况下我们使用jquery.validate.js对用户输入的内容做验证的时候,表单并不是一定包含在form之中,有 ...
- 使用validate.js实现表单数据验证
ASP.NET关于表单验证,目前知道的,除了以前那种傻瓜式的每个表单选项都用一个函数去验证之外,有两种方法是比较方便的,今天先介绍一下第一种,在前端实现表单验证的方法--基于validate.js的表 ...
- element-UI框架使用validate.js的form校验规则(+自定义验证代码)- 应用篇
文章目录 element-UI除了官方给出的校验规则,还可以自定义(举例如下) 代码示例: 参考文章: element-UI除了官方给出的校验规则,还可以自定义(举例如下) element-UI框架f ...
最新文章
- 利用VSPD、串口调试助手、Keil做串口调试
- SQL 聚合函数一定要跟group by以及NULL的关系的案例精讲
- el-drawer点击的时候为什么有边框_80%人都有的表格强迫症怎么破,一招教你自动添加表格边框...
- (八)数据结构之“树”
- 【WebRTC---入门篇】(三)WebRTC运行机制
- oracle 邮件过程,oracle 发邮件 存储过程
- error: failed to push some refs to 'https://gitee.com/xxx/xxx'
- 架​设​W​e​b​服​务​器
- 三范式理解 数据库原理
- 2018-12-08 acm日常 HDU - 6292(模拟找最小)
- Git生成SSH共钥
- 一级 计算机应用基础,一级计算机应用基础(教材浓缩精华版)
- Java基础2讲义四千字总结---黑马刘意
- 【Python数据分析】用户通话行为分析
- IS-IS快速收敛调优(三)——LSP快速洪范、SPF算法改进和按优先级收敛
- 大忽悠:神州行单向收费
- 视频存储网站服务器配置,视频存储服务器配置
- 工控物联网案例-如何利用LTE-658 4G DTU实现水文水利远程物联网监控
- Excel中如何对多个sheet进行同样的操作
- funny_upload