【JavaScript 学习--01】--常用正则表达式

useful_link: http://www.manongjc.com/article/651.html
正则1:replace利用变量法


var curPatt = new RegExp('(\\w+?)(\\d+.*)');
var newPatt = "xL";
//handle data
var newData = _.map(data.results, function (d) {
    d.branch = d.branch.toUpperCase().replace(curPatt, newPatt+"$2");
    return d
});

正则:replace中使用函数

也可以参考 JavaScript Reference Link of Replace
其中date的格式是四位数的年加“-”再加后面的符号,我想把year加+1,再合并后面的字符,返回。
var date = “2014-04”;
先要返回new date = “2015-04”;
代码如下:

var date = "2014-04";
date = date.replace(/(\d{4})(-.*)/, function (match, p1, p2, offset, string) {
    var tmp = parseInt(p1) + 1;
    return tmp+p2;
}),

这里写图片描述

正则:大写每个单词的第一个字母
How to capitalize first letter of each word on JS

var aa = "new feature tab you";
function toTitleCase(str){
    return str.replace(/\w\S*/g, function(txt){
        console.log(txt); //->依次打印new, feature, tab, you
        return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();});
}
console.log(toTitleCase(aa)); //New Feature Tab You
code in my real project!
var name = link.replace(/.*name=(.*?)&.*/, "$1").replace("_", " ").replace(/\w\S*/g, function(txt){return txt.charAt(0).toUpperCase() + txt.substr(1).toLowerCase();});

这里写图片描述

正则2:获取符合条件的特定字符串

比如:想获取z数组中所有以lte开头后面紧跟只是一个数字的,并打印出该字符串以第一空格结束前的字符串。

var z = ["LTE23r.b world", "Lte33-- are right", "you33 changping", "you-are great", "zhou-", "lte3222 sdsfd lte0000"];
        var regExpr = new RegExp('(^LTE\\d+.*?) ', "i");
        z.forEach(function(d) {
            var zz = d.match(regExpr);
            console.log("%j",zz);
            zz ? console.log(zz[1]) : "";
        });
        

该表达式的打印结果如下:
这里match出来的结果是个list,其中list[0]是全表达式符合的字符,list[N]是符合第N个括号里表达式的字符。

%j ["LTE23r.b ", "LTE23r.b", index: 0, input: "LTE23r.b world"]
LTE23r.b
%j ["Lte33-- ", "Lte33--", index: 0, input: "Lte33-- are right"]
Lte33--
%j null
%j null
%j null
%j ["lte3222 ", "lte3222", index: 0, input: "lte3222 sdsfd lte0000"]
lte3222
       

正则三:关于在正则里面用变量方法

var patt = "Jason";
var re =new RegExp("^\\d+" + patt + "$","i"); // re为/^\d+Jason$/i

另外,还有一种方法是用过eval动态执行一段字符串的方法,不过我觉得从各方面来说,都属下策。

var re = eval("/^\\d+" + patt + "$/i")

动态添加正则表达式:

var myStrs = ["hello23 world", "hello-- are right", "you33 changping", "you-are great", "zhou-"];
var regPatts = ["hello", "you"];
var regPatt = "";
regPatts.forEach(function(d) { //structure patt via regPatts
    if (d !=_.last(regPatts)) {
        regPatt += "^" + d + "[-|\\d]|";
    } else {
        regPatt += "^" +d + "[-|\\d]"
    }
});
var newRegPatt = new RegExp(regPatt, "i")
myStrs.forEach(function(d) {
    // var myResult = /(^hello-|^hello\d+)|(^you-|^you\d).+/i.test(d);
    var myResult = newRegPatt.test(d);
    console.log(myResult);//能打印"hello23 world", "hello-- are right", "you33 changping", "you-are great"
});

在list里面添加多个正则表达式:

var VAILD_FEATURE_HEAD = [/LTE/i, /LBT/i, /CNI/i, /CNN/i, /CR/i];
var VAILD_LEGACY =[new RegExp("legacy", "i"), new RegExp("regression", "i")];

之后可以利用$in 和$nin 在db里面查询:

tmpNewF1[featureType] = {$nin:VAILD_LEGACY};
tmpNewF2[featureType] = {$in:VAILD_FEATURE_HEAD};
myNewFeatureFilter["$and"].push(tmpNewF1);
myNewFeatureFilter["$and"].push(tmpNewF2);

常用正则

验证身份证必须18位纯数字,或者17位数字加X: "^(([0-9]){17}(x|X))|([0-9]{18})$"

验证姓名必须为大于2个汉字:"[\\u4e00-\\u9fa5]{2,5}" 或者 [\u4e00-\u9fa5]{2,5}
在这里插入图片描述

验证数字的正则表达式集(转载)

验证数字:^[0-9]*$ 
验证n位的数字:^\d{n}$ 
验证至少n位数字:^\d{n,}$ 
验证m-n位的数字:^\d{m,n}$ 
验证零和非零开头的数字:^(0|[1-9][0-9]*)$ 
验证有两位小数的正实数:^[0-9]+(.[0-9]{2})?$ 
验证有1-3位小数的正实数:^[0-9]+(.[0-9]{1,3})?$ 
验证非零的正整数:^\+?[1-9][0-9]*$ 
验证非零的负整数:^\-[1-9][0-9]*$ 
验证非负整数(正整数 + 0) ^\d+$ 
验证非正整数(负整数 + 0) ^((-\d+)|(0+))$ 
验证长度为3的字符:^.{3}$ 
验证由26个英文字母组成的字符串:^[A-Za-z]+$ 
验证由26个大写英文字母组成的字符串:^[A-Z]+$ 
验证由26个小写英文字母组成的字符串:^[a-z]+$ 
验证由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$ 
验证由数字、26个英文字母或者下划线组成的字符串:^\w+$ 
验证用户密码:^[a-zA-Z]\w{5,17}$ 正确格式为:以字母开头,长度在6-18之间,只能包含字符、数字和下划线。 
验证是否含有 ^%&',;=?$\" 等字符:[^%&',;=?$\x22]+ 
验证汉字:^[\u4e00-\u9fa5],{0,}$ 
验证Email地址:^\w+[-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$ 
验证InternetURL:^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$ ;^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$ 
验证电话号码:^(\d3,4|\d{3,4}-)?\d{7,8}$:--正确格式为:XXXX-XXXXXXX,XXXX-XXXXXXXX,XXX-XXXXXXX,XXX-XXXXXXXX,XXXXXXX,XXXXXXXX。 
验证身份证号(15位或18位数字):^\d{15}|\d{}18$ 
验证一年的12个月:^(0?[1-9]|1[0-2])$ 正确格式为:“01”-“09”和“1”“12” 
验证一个月的31天:^((0?[1-9])|((1|2)[0-9])|30|31)$ 正确格式为:01、09和1、31。 
整数:^-?\d+$ 
非负浮点数(正浮点数 + 0):^\d+(\.\d+)?$ 
正浮点数 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$ 
非正浮点数(负浮点数 + 0) ^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 
负浮点数 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$ 
浮点数 ^(-?\d+)(\.\d+)?

代码段

function check()   
{   
var bb = document.getElementById("txt_id").value;//txt_id为文本框的ID   
alert(ismobile(bb));//ismobile 代表以下任何一个函数名称   
}   

HTML代码:   
<input type="text" name="textfield" id="txt_id" />   
<input type="submit" name="Submit" value="提交" onclick="check()" />   

//   
// 判断输入是否是一个由 0-9 / A-Z / a-z 组成的字符串   
function isalphanumber(str)   
{   
var result=str.match(/^[a-zA-Z0-9]+$/);   
if(result==null) return false;   
return true;   
}   
  
// 判断输入是否是一个数字--(数字包含小数)--   
function isnumber(str)   
{   
return !isNaN(str);   
}   
  
  
// 判断输入是否是一个整数   
function isint(str)   
{   
var result=str.match(/^(-|\+)?\d+$/);   
if(result==null) return false;   
return true;   
}   
  
  
// 判断输入是否是有效的长日期格式 - "YYYY-MM-DD HH:MM:SS" || "YYYY/MM/DD HH:MM:SS"   
function isdatetime(str)   
{   
var result=str.match(/^(\d{4})(-|\/)(\d{1,2})\2(\d{1,2}) (\d{1,2}):(\d{1,2}):(\d{1,2})$/);   
if(result==null) return false;   
var d= new Date(result[1], result[3]-1, result[4], result[5], result[6], result[7]);   
return (d.getFullYear()==result[1]&&(d.getMonth()+1)==result[3]&&d.getDate()==result[4]&&d.getHours()==result[5]&&d.getMinutes()==result[6]&&d.getSeconds()==result[7]);   
}   
  
  
// 检查是否为 YYYY-MM-DD || YYYY/MM/DD 的日期格式   
function isdate(str){   
var result=str.match(/^(\d{4})(-|\/)(\d{1,2})\2(\d{1,2})$/);   
if(result==null) return false;   
var d=new Date(result[1], result[3]-1, result[4]);   
return (d.getFullYear()==result[1] && d.getMonth()+1==result[3] && d.getDate()==result[4]);   
}   
  
  
// 判断输入是否是有效的电子邮件   
function isemail(str)   
{   
var result=str.match(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/);   
if(result==null) return false;   
return true;   
}   
  
  
// 去除字符串的首尾的空格   
function trim(str){   
return str.replace(/(^\s*)|(\s*$)/g, "");   
}   
  
  
// 返回字符串的实际长度, 一个汉字算2个长度   
function strlen(str){   
return str.replace(/[^\x00-\xff]/g, "**").length;   
}   
  
  
//匹配中国邮政编码(6位)   
function ispostcode(str)   
{   
var result=str.match(/[1-9]\d{5}(?!\d)/);   
if(result==null) return false;   
return true;   
}   
//匹配国内电话号码(0511-4405222 或 021-87888822)   
function istell(str)   
{   
var result=str.match(/\d{3}-\d{8}|\d{4}-\d{7}/);   
if(result==null) return false;   
return true;   
}   
  
//校验是否为(0-10000)的整数   
function isint1(str)   
{   
var result=str.match(/^[0-9]$|^([1-9])([0-9]){0,3}$|^10000$/);   
if(result==null) return false;   
return true;   
}   
  
  
//匹配腾讯QQ号   
function isqq(str)   
{   
var result=str.match(/[1-9][0-9]{4,}/);   
if(result==null) return false;   
return true;   
}   
  
  
//匹配身份证(15位或18位)   
function isidcard(str)   
{   
var result=str.match(/\d{15}|\d{18}/);   
if(result==null) return false;   
return true;   
}   
//   
  
   
  
//校验文本是否为空   
function checknull(field,sval)   
{   
if (field.value =="")   
{   
alert("请填写" + sval + "!");   
field.focus();   
return false;   
}   
return true;   
}   
  
  
//屏蔽输入字符   
/***********************  
调用方法:  
在文本框中加上 onkeypress="return checkChar()"  
*************************/   
function checkChar()   
{   
var keycode = event.keyCode;   
if(!(keycode>=48&&keycode<=57))   
{   
return false;   
}   
}   
  
  
/***************************************************************************************************************************   
中国电话号码验证   
匹配形式如:0511-4405222 或者021-87888822 或者 021-44055520-555 或者 (0511)4405222   
正则表达式 "((d{3,4})|d{3,4}-)?d{7,8}(-d{3})*"   
  
中国邮政编码验证   
匹配形式如:215421   
正则表达式 "d{6}"   
  
电子邮件验证   
匹配形式如:justali@justdn.com   
正则表达式 "w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*"   
  
身份证验证   
匹配形式如:15位或者18位身份证   
正则表达式 "d{18}|d{15}"   
  
常用数字验证   
正则表达式   
"d{n}" n为规定长度   
"d{n,m}" n到m的长度范围   
  
非法字符验证   
匹配非法字符如:< > & / ' |   
正则表达式 [^<>&/|'\]+   
  
日期验证   
匹配形式如:20030718,030718   
范围:1900--2099   
正则表达式((((19){1}|(20){1})d{2})|d{2})[01]{1}d{1}[0-3]{1}d{1}   
  
  
  
匹配中文字符的正则表达式: [\u4e00-\u9fa5]   
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了   
  
匹配双字节字符(包括汉字在内):[^\x00-\xff]   
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)   
  
匹配空白行的正则表达式:\n\s*\r   
评注:可以用来删除空白行   
  
匹配HTML标记的正则表达式:< (\S*?)[^>]*>.*?|< .*? />   
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力   
  
匹配首尾空白字符的正则表达式:^\s*|\s*$   
评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式   
  
匹配Email地址的正则表达式:\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*   
评注:表单验证时很实用   
  
匹配网址URL的正则表达式:[a-zA-z]+://[^\s]*   
评注:网上流传的版本功能很有限,上面这个基本可以满足需求   
  
匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$   
评注:表单验证时很实用   
  
匹配国内电话号码:\d{3}-\d{8}|\d{4}-\d{7}   
评注:匹配形式如 0511-4405222 或 021-87888822   
  
匹配腾讯QQ号:[1-9][0-9]{4,}   
评注:腾讯QQ号从10000开始   
  
匹配中国邮政编码:[1-9]\d{5}(?!\d)   
评注:中国邮政编码为6位数字   
  
匹配身份证:\d{15}|\d{18}   
评注:中国的身份证为15位或18位   
  
匹配ip地址:\d+\.\d+\.\d+\.\d+   
评注:提取ip地址时有用   
  
提取信息中的ip地址:   
(\d+)\.(\d+)\.(\d+)\.(\d+)   
  
提取信息中的中国手机号码:   
(86)*0*13\d{9}   
  
提取信息中的中国固定电话号码:   
(\d3,4|\d{3,4}-|\s)?\d{8}   
  
提取信息中的中国电话号码(包括移动和固定电话):   
(\d3,4|\d{3,4}-|\s)?\d{7,14}   
  
提取信息中的中国邮政编码:   
[1-9]{1}(\d+){5}   
  
提取信息中的中国身份证号码:   
\d{18}|\d{15}   
  
提取信息中的整数:   
\d+   
  
提取信息中的浮点数(即小数):   
(-?\d*)\.?\d+   
  
提取信息中的任何数字 :   
(-?\d*)(\.\d+)?   
  
提取信息中的中文字符串:   
[\u4e00-\u9fa5]*   
  
提取信息中的双字节字符串 (汉字):   
[^\x00-\xff]*   
  
提取信息中的英文字符串:   
\w*   
提取信息中的网络链接:   
(h|H)(r|R)(e|E)(f|F) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?   
  
提取信息中的邮件地址:   
\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*   
  
提取信息中的图片链接:   
(s|S)(r|R)(c|C) *= *('|")?(\w|\\|\/|\.)+('|"| *|>)?   
  
  
匹配特定数字:   
^[1-9]\d*$    //匹配正整数   
^-[1-9]\d*$   //匹配负整数   
^-?[1-9]\d*$   //匹配整数   
^[1-9]\d*|0$  //匹配非负整数(正整数 + 0)   
^-[1-9]\d*|0$   //匹配非正整数(负整数 + 0)   
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$   //匹配正浮点数   
^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$  //匹配负浮点数   
^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$  //匹配浮点数   
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$   //匹配非负浮点数(正浮点数 + 0)   
^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$  //匹配非正浮点数(负浮点数 + 0)   
评注:处理大量数据时有用,具体应用时注意修正   
  
匹配特定字符串:   
^[A-Za-z]+$  //匹配由26个英文字母组成的字符串   
^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串   
^[a-z]+$  //匹配由26个英文字母的小写组成的字符串   
^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串   
^\w+$  //匹配由数字、26个英文字母或者下划线组成的字符串   
评注:最基本也是最常用的一些表达式   
  
  
  
前4行程序用于保护js代码不被下载   
// 基本正则表达式///   
//非空验证 function NotNull (str) { return (str!=""); }   
//邮件地址验证   
function checkEmail (str) {   
//邮件地址正则表达式 isEmail1=/^\w+([\.\-]\w+)*\@\w+([\.\-]\w+)*\.\w+$/;   
//邮件地址正则表达式 isEmail2=/^.*@[^_]*$/;   
//验证邮件地址,返回结果 return (isEmail1.test(str)&&isEmail2.test(str));   
} //身份证验证 function checkIDCard (str) {   
//身份证正则表达式(15位)   
isIDCard1=/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;   
//身份证正则表达式(18位) isIDCard2=/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{4}$/;   
//验证身份证,返回结果 return (isIDCard1.test(str)||isIDCard2.test(str)); }   
//IP验证 function checkIP (str)   
{ //IP正则表达式 IP='(25[0-5]|2[0-4]\\d|1\\d\\d|\\d\\d|\\d)';   
IPdot=IP+'\\.'; isIPaddress=new RegExp('^'+IPdot+IPdot+IPdot+IP+'$');   
//验证IP,返回结果 return (isIPaddress.test(str)); }   
//主页(网址)验证 function checkHomepage (str) {   
//主页正则表达式 //isHomepage=/^\w+([\.\-]\w)*$/; isHomepage=/^\w+(\.\w+)+\.\w+$/;   
//验证主页,返回结果 return (isHomepage.test(str)); }   
//是否数字 function isNum (str) { //isNumber=/^([1-9]\d*(\.\d+)?)|(\d+(\.\d+))$/; isNumber=/^\d+(\.\d+)?$/;   
//验证并返回结果 return (isNumber.test(str)); }   
//是否整数 function isInt (str) { isInteger=/^\d+$/;   
//验证并返回结果 return (isInteger.test(str)); }   
//是否字母 function isChar (str) { isCharacter=/^[A-Za-z]+$/;   
//验证并返回结果 return (isCharacter.test(str)); }   
/基本弹出窗口///   
function checkBoolean(bv,i,w) { if(bv==false) { try{i.focus();}catch(e){} alert(w); return false; } return true }   

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

木瓜~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值