js 各种常用js验证

判断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_!~*‘().&=+$%-][email protected])?" //ftp的[email protected]            + "(([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.如果左侧部分包含-、_、.则这些特殊符号的前面必须包一位数字或字母。    * [email protected]符号是必填项    * 4.右则部分可分为两部分,第一部分为邮件提供商域名地址,第二部分为域名后缀,现已知的最短为2位。最长的为6为。    * 5.邮件提供商域可以包含特殊字符-、_、.    */    var pattern = /^([a-zA-Z0-9]+[-_.]?)*[a-zA-Z0-9][email protected]([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] + "/" + arrSplit[4]);        var bGoodDay;        bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4]));        if (!bGoodDay) {            //alert(dtmBirth.getYear());            //alert(arrSplit[2]);            //alert(‘输入的身份证号里出生日期不对!‘);            return false;        }        else {            //检验18位身份证的校验码是否正确。            //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。            var valnum;            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;            for (k = 0; k < 17; k++) {                nTemp += num.substr(k, 1) * arrInt[k];            }            valnum = arrCh[nTemp % 11];            if (valnum != num.substr(17, 1)) {                //alert(‘18位身份证的校验码不正确!应该为:‘ + valnum);                return false;            }            return true;        }    }    return false;}

2015-03-22ShareComments

时间: 2024-10-12 19:16:53

js 各种常用js验证的相关文章

JS的常用正则表达式 验证密码用户名等

JS的正则表达式 //校验是否全由数字组成 function isDigit(s){var patrn=/^[0-9]{1,20}$/;if (!patrn.exec(s)) return falsereturn true} //校验登录名:只能输入5-20个以字母开头.可带数字.“_”.“.”的字串Java代码function isRegisterUserName(s)  {  var patrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/;  if (!p

js常用的验证正则表达式

js 正则表达式使用讲解:各种验证语法 intege:"^-?[1-9]//d*$",     //整数 intege1:"^[1-9]//d*$",     //正整数 intege2:"^-[1-9]//d*$",     //负整数 num:"^([+-]?)//d*//.?//d+$",   //数字 num1:"^[1-9]//d*|0$",     //正数(正整数 + 0) num2:&quo

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

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

外贸建站之常用JS邮箱地址验证代码分享

外贸建站之常用JS邮箱地址验证代码分享 <script> function fpa_keyword_sub(){ var mail = $("#email_fpa").val(); if(! mail.match(/^(?:[a-zA-Z0-9]+[_\-\+\.]?)*[a-zA-Z0-9]+@(?:([a-zA-Z0-9]+[_\-]?)*[a-zA-Z0-9]+\.)+([a-zA-Z]{2,})+$/)){ alert("Email error!"

常用js特效

事件源对象  event.srcElement.tagName event.srcElement.type 捕获释放  event.srcElement.setCapture();  event.srcElement.releaseCapture(); 事件按键  event.keyCode event.shiftKey event.altKey event.ctrlKey 事件返回值  event.returnValue 鼠标位置 event.x event.y 窗体活动元素  documen

利用Node.js实现模拟Session验证的登陆

1.身份验证和用户登陆 在一般的Web应用上,如果要实现用户登陆,最常用,也是最简单的方法就是使用Session,基本的思路是在Session中保留一些用户身份信息,然后每次在Session中取,如果信息不正确或不存在,那么身份验证失败,正确则成功. Session和Cookie是两个很相似的东西,都是字符串,只不过Session是保存在服务器上的,而Cookie是保存在本地的,所以Cookie是不能用作身份验证的.Session故名思议,肯定和客户端与服务器间建立的会话相关,Session的工

常用JS正则匹配函数

//校验用户名:只能输入1-30个字母 function isTrueName(s) { var patrn=/^[a-zA-Z]{1,30}$/; if (!patrn.exec(s)) return false return true } //校验密码:只能输入6-20个字母.数字.下划线 function isPasswd(s) { var patrn=/^(/w){6,20}$/; if (!patrn.exec(s)) return false return true } //校验普通

JS中常用开发知识点

 JS中常用开发知识点 1.获取指定范围内的随机数 2.随机获取数组中的元素 3.生成从0到指定值的数字数组 等同于: 4.打乱数字数组的顺序 5.对象转换为数组 //注意对象必须是以下格式的才可以通过此方式转化为数组 //获取的DOM集合,以及函数的arguments也可以通过此方式转化为数组 6.验证是否为数组 7.获取数组中最大或者最小值 8.清空数组 9.保留指定小数位 10.生成指定长度的随机字母数字字符串 11.找出数组中出现次数最的元素,并给出其出现过的位置 原文地址:https:

Js中常用的字符串,数组,函数扩展

由于最近辞职在家,自己的时间相对多一点.所以就根据prototytpeJS的API,结合自己正在看的司徒大神的<javascript框架设计>,整理了下Js中常用一些字符串,数组,函数扩展,一来可以练练手,二来也锻炼下自己的代码能力.由于代码里面的注释自认为已经非常详细,所以就直接贴代码了. 1. 字符串扩展: ;(function() { var method, stringExtends = { /** * 删除字符串开始和结尾的空白 * @returns {string} */ stri