前端的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相关推荐

  1. jQuery验证控件jquery.validate.js使用说明+中文API

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

  2. jq.validate.js

    首选必须是要下载滴,jq.validate.js表单效验方式. 建立form表单没得说 <form id="form"><p><label for=& ...

  3. jQuery.validate.js API

    为什么80%的码农都做不了架构师?>>>    jQuery.validate.js API 转载于:https://my.oschina.net/azheng/blog/10281

  4. jQuery表单校验jquery.validate.js的使用

    jQuery是一个快速.简洁的js库,为网站的快速开发简化了HTML文档遍历,事件处理,动画,以及Ajax交互.使用jQuery将极大的提高编写javascript代码的效率, 让写出来的代码更加优雅 ...

  5. jquery.validate.js插件的使用方法

    近期做项目.须要用到 jQuery.validate.js插件,于是记录一下工作中的一些经验,以便日后学习. [样例例如以下] 1.前台页面 <form id="form1" ...

  6. ASP.NETmvc常用JQUERY收藏【jquery.form.js结合jquery.validate.js】

    虽然jquery.form.js可以通过自定义验证方式实现个性化的验证,不过我们大量使用的还不是一个红星(*) 在jquery.form.js下使用jquery.validate.js就可以简简单单的 ...

  7. 当同时使用bootstrap-datepicker.js和jquery.validate.js这两款插件,至少要选择两次时间,才能验证成功的问题...

    当用 bootstrap-datepicker.js 这个插件选择时间,再用jquery.validate.js进行验证,当时间不为空时则验证通过.可能由于在时间插件弹出来时,input框的值发生改变 ...

  8. 修改 jquery.validate.js 支持非form标签

    尝试使用markdown来写一篇blog,啦啦啦 源代码传送门:github 在特殊情况下我们使用jquery.validate.js对用户输入的内容做验证的时候,表单并不是一定包含在form之中,有 ...

  9. 使用validate.js实现表单数据验证

    ASP.NET关于表单验证,目前知道的,除了以前那种傻瓜式的每个表单选项都用一个函数去验证之外,有两种方法是比较方便的,今天先介绍一下第一种,在前端实现表单验证的方法--基于validate.js的表 ...

  10. element-UI框架使用validate.js的form校验规则(+自定义验证代码)- 应用篇

    文章目录 element-UI除了官方给出的校验规则,还可以自定义(举例如下) 代码示例: 参考文章: element-UI除了官方给出的校验规则,还可以自定义(举例如下) element-UI框架f ...

最新文章

  1. 利用VSPD、串口调试助手、Keil做串口调试
  2. SQL 聚合函数一定要跟group by以及NULL的关系的案例精讲
  3. el-drawer点击的时候为什么有边框_80%人都有的表格强迫症怎么破,一招教你自动添加表格边框...
  4. (八)数据结构之“树”
  5. 【WebRTC---入门篇】(三)WebRTC运行机制
  6. oracle 邮件过程,oracle 发邮件 存储过程
  7. error: failed to push some refs to 'https://gitee.com/xxx/xxx'
  8. 架​设​W​e​b​服​务​器
  9. 三范式理解 数据库原理
  10. 2018-12-08 acm日常 HDU - 6292(模拟找最小)
  11. Git生成SSH共钥
  12. 一级 计算机应用基础,一级计算机应用基础(教材浓缩精华版)
  13. Java基础2讲义四千字总结---黑马刘意
  14. 【Python数据分析】用户通话行为分析
  15. IS-IS快速收敛调优(三)——LSP快速洪范、SPF算法改进和按优先级收敛
  16. 大忽悠:神州行单向收费
  17. 视频存储网站服务器配置,视频存储服务器配置
  18. 工控物联网案例-如何利用LTE-658 4G DTU实现水文水利远程物联网监控
  19. Excel中如何对多个sheet进行同样的操作
  20. funny_upload

热门文章

  1. jupyter内核配置问题
  2. Linux 3.10内核锁瓶颈描述以及解决-overlayfs的性能缺陷
  3. matlab里面nargin,Matlab中的nargin命令
  4. 浅谈大数据领域的云计算
  5. AutoFac基本使用-笔记
  6. 周志华 AdaBoost报告总结
  7. NAT网关(SNAT,DNAT)
  8. 贪心算法——1225:金银岛
  9. python字符串设置字体_[4] Python字符串
  10. 北京多家大型驾校酝酿至少涨价10%