判断http或者https

var http = 'https:' == document.location.protocol ? false : true;

js的类型检测方式

/**** js的类型检测方式->typeof、constuctor。* 推荐通过构造函数来检测变量的类型。*/var obj = {key:'value'}, arr = ["hello","javascript"], fn = function(){}, str = "hello js", num = 55, bool = true, User = function(){}, user = new User(); /*typeof测试*/ console.log(typeof obj); //obj console.log(typeof arr); //obj console.log(typeof fn); //function console.log(typeof str); //string console.log(typeof num); //number console.log(typeof bool); //boolean console.log(typeof user); //object /*constructor测试*/ console.log(obj.constructor == Object); //true console.log(arr.constructor == Array); //true console.log(str.constructor == String); //true console.log(num.constructor == Number); //true console.log(bool.constructor == Boolean);//true console.log(user.constructor == User); //true

单词首字母大写

/**** 将单个字符串的首字母大写*/var fistLetterUpper = function(str) { return str.charAt(0).toUpperCase()+str.slice(1);};console.log(fistLetterUpper('hello')); //Helloconsole.log(fistLetterUpper('good')); //Good

/**** @descrition:判断是否是合理的IP地址* @param:str->待验证的IP地址* @return :true合理的IP地址* */var isIP = function (str) { var pattern = /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/;

 return pattern.test(str);}

URL参数验证

/*** @descrition:判断输入的参数是否是个合格的URL,由于url的灵活性和多样性,一下代码并不能测试所有的url都是合法的(PS:该正则无法通配所有的URL,请慎用)* @param:str->待判断的url参数* @return :true表示符合改正则。**/var isURL = function (str) { var strRegex = "^((https|http|ftp|rtsp|mms)?://)" + "?(([0-9a-z_!~*'().&=+$%-]+: )?[0-9a-z_!~*'().&=+$%-]+@)?" //ftp的user@ + "(([0-9]{1,3}.){3}[0-9]{1,3}" // IP形式的URL- 199.194.52.184 + "|" // 允许IP和DOMAIN(域名) + "([0-9a-z_!~*'()-]+.)*" // 域名- www. + "([0-9a-z][0-9a-z-]{0,61})?[0-9a-z]." // 二级域名 + "[a-z]{2,6})" // first level domain- .com or .museum + "(:[0-9]{1,4})?" // 端口- :80 + "((/?)|" + "(/[0-9a-z_!~*'().;?:@&=+$,%#-]+)+/?)$"; var re = new RegExp(strRegex);

 return re.test(str);}

邮编地址验证

/**** @descrition:判断输入的参数是否是国内合法的邮编地址(ps:国内不包含国外的邮编)* @link: http://www.youbianku.com/%E9%A6%96%E9%A1%B5* @param: str为待验证的邮编号码* @return: true表示为合法的邮编号码* */var isPostcode = function(str) { //国内邮编以0-8开头的6为数字 var pattern = /^[0-8]\d{5}$/; return pattern.test(str);

}

QQ号码验证

/**** @descrition:判断输入的参数是否是个合格的QQ号码* @param->str:待验证的参数* @return: true验证成功*/var isQQ = function(str) { /** *@descrition:规则 * 1-9开头,最少5位。 */ var pattern = /^[1-9][0-9]{4,}$/ return pattern.test(str);}

手机号码验证

/**** @descrition:判断输入的参数是否是个合格的手机号码,不能判断号码的有效性,有效性可以通过运营商确定。* @param:str ->待判断的手机号码* @return: true表示合格输入参数* */var isCellphone = function(str) { /** *@descrition:手机号码段规则 * 13段:130、131、132、133、134、135、136、137、138、139 * 14段:145、147 * 15段:150、151、152、153、155、156、157、158、159 * 17段:170、176、177、178 * 18段:180、181、182、183、184、185、186、187、188、189 *  */ var pattern = /^(13[0-9]|14[57]|15[012356789]|17[0678]|18[0-9])\d{8}$/; return pattern.test(str);}

固定电话号码验证

/*** @descrition:判断输入的参数是否是个合格的固定电话号码。* @param:str->待验证的固定电话号码。* @return : true表示验证合格。* **/var isfixedphone = function(str) { /** * * @desctition:规则->区号3-4位,号码7-8位,可以有分机号,分机号为3-4为,格式如下:"0775-85333333-123" *  */ var pattern = /^\d{3,4}-\d{7,8}(-\d{3,4})?$/; return pattern.test(str);}

标准的邮箱验证

/**** @descrition:判断输入的参数是否是个合格标准的邮箱,并不能判断是否有效,有效只能通过邮箱提供商确定。* @param:str ->待验证的参数。* @return -> true表示合格的邮箱。* */var isEmail = function(str){ /** * @descrition:邮箱规则 * 1.邮箱以a-z、A-Z、0-9开头,最小长度为1. * 2.如果左侧部分包含-、_、.则这些特殊符号的前面必须包一位数字或字母。 * 3.@符号是必填项 * 4.右则部分可分为两部分,第一部分为邮件提供商域名地址,第二部分为域名后缀,现已知的最短为2位。最长的为6为。 * 5.邮件提供商域可以包含特殊字符-、_、. */ var pattern = /^([a-zA-Z0-9]+[-_.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[-_.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,6}$/; return pattern.test(str);}

判断传入的参数的长度是否在给定的有效范围内

/**** @description: 判断传入的参数的长度是否在给定的有效范围内* @param: minL->给定的最小的长度* @param: maxL->给定的最大的长度* @param: str->待验证的参数* @return : true表示合理,验证通过* */var isAvaiableLength = function(minL,maxL,str){ return (str.length >= minL && str.length <= maxL) ? true : false;}

判断输入的参数是否为空

/**** @Dependence : https://gist.github.com/hehongwei44/3e167cfcda47d4c8051a#file-extendstringprototype-js* @description : 判断输入的参数是否为空* @return : true表示为输入参数为空 * */var isEmpty = function (str) { //空引用 空字符串 空输入 return str == null || typeof str == "undefined" || str.trim() == "" ? true : false;}

测试给定的参数是否全部为中文字符

/**** @descrition: 测试给定的参数是否全部为中文字符,如"中test"不会通过 。* @param->str : 传入的参数,类型为字符串。* @return : true表示全部为中文,false为不全是中文,或没有中文。* */var isChinese = function (str) { var pattern = /^[\u0391-\uFFE5]+$/g; return pattern.test(str);}

数字类型验证

/**** @descrition : 该函数的功能是判断转入的参数是否为数字类型。* @param->o   : 传入的参数,参数可以为任何类型。* @return: true表示为数字,false为非数字* */var isNumber = function(o) { return !isNaN(o);}

对String类型去除空格的拓展

/**** @desccrition: 对String类型去除空格的拓展* @dir : 被去除空格所在的位置* @test: ie6-9 chrome firefox*/String.prototype.trim = function(dir){ switch (dir) { case 0 : //去左边的空格 return this.replace(/(^\s*)/g,''); break; case 1 : //去右边的空格 return this.replace(/(\s*$)/g,''); break; case 2 : //去掉所有的空格 return this.replace(/(\s*)/g,''); break; default : //去掉两边的空格 return this.replace(/(^\s*)|(\s*$)/g,''); }}

对字符串进行截取,包括普通字符和中文字符

/**** @descrition: 对字符串进行截取,包括普通字符和中文字符* @param : str ->待截取的字符串* @param : len ->要截取的长度* * 比如cutstr('hello',2)->he... cutstr("您好呀",4)->您好...* 优先选择后台进行字符串截取,后css截取,最后js截取*/var cutstr = function(str, len) { var temp, icount = 0, patrn = /[^\x00-\xff]/g, //中文字符匹配 strre = "";

 for (var k = 0; k < str.length; k++) { if (icount < len ) { temp = str.substr(k, 1); if (temp.match(patrn) == null) { icount = icount + 1; } else { icount = icount + 2; } strre += temp; } else { break } } return strre + "...";}

生成随机的字符串

/*** @function:generateRandomAlphaNum->生成随机的字符串* @param:len->生存随机字符串的长度* @tdd->IE6-9 chrome Firefox通过测试* */function generateRandomAlphaNum(len) { var rdmString = ""; //toSting接受的参数表示进制,默认为10进制。36进制为0-9 a-z for (; rdmString.length < len; rdmString += Math.random().toString(36).substr(2)); return rdmString.substr(0, len);}

通过a标签解析url标签

/** @function: 通过a标签解析url标签* @param:url  url参数是字符串,解析的目标  通过IE6-9 chrome  Firefox测试**/function parseURL(url) { //创建一个a标签 var a = document.createElement('a'); //将url赋值给标签的href属性。 a.href = url; return { source: url, protocol: a.protocol.replace(':',''), //协议 host: a.hostname, //主机名称 port: a.port, //端口 query: a.search, //查询字符串 params: (function(){ //查询参数 var ret = {}, seg = a.search.replace(/^\?/,'').split('&'), len = seg.length, i = 0, s; for (;i<len;i++) { if (!seg[i]) { continue; } s = seg[i].split('='); ret[s[0]] = s[1]; } return ret; })(), file: (a.pathname.match(/\/([^\/?#]+)$/i) || [,''])[1], //文件名 hash: a.hash.replace('#',''), //哈希参数 path: a.pathname.replace(/^([^\/])/,'/$1'), //路径 relative: (a.href.match(/tps?:\/\/[^\/]+(.+)/) || [,''])[1], //相对路径 segments: a.pathname.replace(/^\//,'').split('/') //路径片段 };}

身份证号码验证

/**** @descrition: 判断输入的参数是否是一个合格的身份证号码。这个函数对输入的参数检查时候是合格的身份证号码,其身份证有效性无法判断。检测的颗粒度可以定制。* @param->str : 待验证的参数* @return : true是合格的身份证 false为不合法的身份证* */var checkIdCard = function (num) { num = num.toUpperCase();

 var cityCode = {11: "北京", 12: "天津", 13: "河北", 14: "山西", 15: "内蒙古", 21: "辽宁", 22: "吉林", 23: "黑龙江 ", 31: "上海", 32: "江苏", 33: "浙江", 34: "安徽", 35: "福建", 36: "江西", 37: "山东", 41: "河南", 42: "湖北 ", 43: "湖南", 44: "广东", 45: "广西", 46: "海南", 50: "重庆", 51: "四川", 52: "贵州", 53: "云南", 54: "西藏 ", 61: "陕西", 62: "甘肃", 63: "青海", 64: "宁夏", 65: "新疆", 71: "台湾", 81: "香港", 82: "澳门", 91: "国外 "};

 if(!cityCode[num.substr(0,2)]){ alert("地址编码错误"); return false; } //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。 if (!(/(^\d{15}$)|(^\d{17}([0-9]|X)$)/.test(num))) { //alert('输入的身份证号长度不对,或者号码不符合规定!\n15位号码应全为数字,18位号码末位可以为数字或X。'); return false; } //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。 //下面分别分析出生日期和校验位 var len, re; len = num.length; if (len == 15) { re = new RegExp(/^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/); var arrSplit = num.match(re);

 //检查生日日期是否正确 var dtmBirth = new Date('19' + arrSplit[2] + '/' + arrSplit[3] + '/' + arrSplit[4]); var bGoodDay; bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4])); if (!bGoodDay) { //alert('输入的身份证号里出生日期不对!'); return false; } else { //将15位身份证转成18位 //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。 var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); var nTemp = 0, k; num = num.substr(0, 6) + '19' + num.substr(6, num.length - 6); for (k = 0; k < 17; k++) { nTemp += num.substr(k, 1) * arrInt[k]; } num += arrCh[nTemp % 11]; return true; } } if (len == 18) { re = new RegExp(/^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/); var arrSplit = num.match(re);

 //检查生日日期是否正确 var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + 

转载于:https://www.cnblogs.com/zccst/p/4717957.html

js 各种常用js验证相关推荐

  1. JS的常用正则表达式 验证密码

    JS的正则表达式强:字母+数字+特殊字符 ^(?![a-zA-z]+$)(?!\d+$)(?![!@#$%^&*]+$)(?![a-zA-z\d]+$)(?![a-zA-z!@#$%^& ...

  2. [JS代码]常用JS网页广告代码

    (http://bbs.blueidea.com/thread-2430778-1-1.html) 整理了几个常用的网页广告代码 演示地址: http://www.makewing.com/lanre ...

  3. 【JS】常用js方法

    1.判断是否是数组.字符串等方法 a instanceof b a是你需要判断的数据 b是判断的类型 //直接判断原型 var a = [1,5,8] var b = '123456'console. ...

  4. JS中常用正则转换和信息验证的封装(80个)

    JS中常用正则转换和信息验证的封装(80个) 邮箱 手机号码 电话号码 是否url地址 是否字符串 是否数字 是否boolean 是否函数 是否为null 是否undefined 是否对象 是否数组 ...

  5. 【卡法 常用 ckl.js 库】: js汇合 表单验证 cookie设置 日期格式 电话手机号码 email 整数 小数 金额 检查参数长度...

    [卡法 常用js库]: js汇合 表单验证  cookie设置  日期格式  电话手机号码  email  整数  小数  金额   检查参数长度 // +---------------------- ...

  6. api日常总结:前端常用js函数和CSS常用技巧

    我的移动端media html{font-size:10px} @media screen and (min-width:321px) and (max-width:375px){html{font- ...

  7. JS通用表单验证函数

    Check.js   JS函数文件 /*  *--------------- 客户端表单通用验证CheckForm(oForm) -----------------  * 功能:通用验证所有的表单元素 ...

  8. js的常用封装函数库之Number操作

    js的常用封装函数库之Number操作: /* * 函数功能:Number */class NumberFn {/*随机数范围*/random (min, max) {if (arguments.le ...

  9. 【Springboot 入门培训】# 17 WebJars + BootStrap5 常用JS组件应用

    在传统的前后一体项目开发中,大部分人会使用到BootStrap加其它JS组件的配合方式来完成页面UI功能的实现.下面介绍几种常用的JS库的使用方法.代码例子下载 目录 1 树形组件 1.1 TreeJ ...

最新文章

  1. Pydev 找不到新安装的 Python egg 解决方法
  2. matlab 三维饼图,重新学习MATLAB——作图技法及3D可视化
  3. Android OpenGL ES 开发教程(20):颜色Color
  4. 架构师最怕程序员知道的十件事
  5. WindowsPhone-GameBoy模拟器开发四--Gameboy显示系统分析
  6. echarts生成图表
  7. Python re 库的正确使用姿势
  8. Apache+PHP 无法加载 MySql 模块的问题
  9. 深入学习java虚拟机第二版学习笔记
  10. python汉化补丁包怎么安装_如何安装python包
  11. 显卡测试软件硬盘版怎么安装,显卡检测软件(Alexander)
  12. app系统软件开发外包的费用:开发app多少钱的费用?
  13. 哈里王子与魔兽圣骑士(Paladin)
  14. 【Java】Java中GUI之布局管理器
  15. FMT-Autopilot Ubuntu环境搭建
  16. 公众号榜单 | 2020·6月公众号地区排行榜重磅发布
  17. android手机各大分区详解
  18. sql 当前时间加一天
  19. 小学生算术加法测试c 语言,程序设计方法学课程设计--小学生算术四则运算测试程序(C)...
  20. ExtJs定制日历控件——定制部分解析

热门文章

  1. python查询缺失值所在位置使用scipy_python – 使用缺失值计算scipy中的成对距离
  2. mysql导入数据io异常_mysql 数据同步 出现Slave_IO_Running:No问题的解决方法小结
  3. 打包tomcat没有xml文件_Spring Boot 项目打包 War 并部署到 Tomcat
  4. bscroll 滚动位置_better-scroll初始滚动位置
  5. python name_python中__name__的使用
  6. python tkinter设置窗口大小_Python: tkinter窗口屏幕居中,设置窗口最大,最小尺寸实例...
  7. mysql管理用户数据库_MySQL 数据库管理(一)(用户与受权)
  8. 【js】四种自定义对象的常见方法
  9. Ant Design Vue中a-select组件下拉列表在局部滚动时不跟随问题解决方法
  10. ios .framework动态库重签名