【JavaScript 学习--01】--常用正则表达式
2016-08-05 10:24
627 查看
useful_link: http://www.manongjc.com/article/651.html
正则1:replace利用变量法
正则:replace中使用函数
也可以参考 JavaScript Reference Link of Replace
其中date的格式是四位数的年加“-”再加后面的符号,我想把year加+1,再合并后面的字符,返回。
var date = “2014-04”;
先要返回new date = “2015-04”;
代码如下:
正则:大写每个单词的第一个字母
How to capitalize first letter of each word on JS
正则2:获取符合条件的特定字符串
比如:想获取z数组中所有以lte开头后面紧跟只是一个数字的,并打印出该字符串以第一空格结束前的字符串。
该表达式的打印结果如下:
这里match出来的结果是个list,其中list[0]是全表达式符合的字符,list
是符合第N个括号里表达式的字符。
正则三:关于在正则里面用变量方法
另外,还有一种方法是用过eval动态执行一段字符串的方法,不过我觉得从各方面来说,都属下策。
动态添加正则表达式:
在list里面添加多个正则表达式:
之后可以利用$in 和$nin 在db里面查询:
正则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< 129fb /span> 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个括号里表达式的字符。
%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);
验证数字的正则表达式集(转载)
验证数字:^[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 }
相关文章推荐
- 【JavaScript 学习--01】--正则表达式的正则前瞻(?=)和非捕获性分组(?:)区别
- 一些常用的JavaScript正则表达式
- javascript常用正则表达式[收藏]
- 常用的JavaScript验证正则表达式
- javascript中正则表达式应用学习_test()
- 常用的JavaScript验证正则表达式
- 常用的javascript匹配正则表达式和实例
- javascript正则表达式学习笔记
- 常用Javascript正则表达式
- 常用的JavaScript验证正则表达式
- 常用的JavaScript验证正则表达式
- [收藏]JavaScript常用的正则表达式应用(ip,email,data,time)
- JavaScript常用正则表达式
- JavaScript常用的正则表达式应用(身份证号码)
- JavaScript常用正则表达式
- javascript 中一些常用的正则表达式
- 通过时间校验学习JavaScript正则表达式
- 通过时间校验学习JavaScript正则表达式
- javascript中正则表达式应用学习_match()
- [JavaScript]正则表达式学习