加入收藏 | 设为首页 | 会员中心 | 我要投稿 常州站长网 (https://www.0519zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

JavaScript中常用的正则表达式日常整理(全)

发布时间:2016-11-29 03:31:47 所属栏目:大数据 来源:站长网
导读://校验是否全由数字组成 function isDigit(s) { var patrn=/^[0-9]{1,20}$/; if (!patrn.exec(s)) return false return true } 匹配中文字符的正则表达式: [u4e00-u9fa5] 评注:匹配中文还真是个头疼的事,有了这个表达式就好办了 匹配双字节字符(包括汉

测试代码如下:

lt;script type="text/javascript"gt; 
function testReg(reg,str){ 
return reg.test(str); 
} 
var reg = /^d{4}-d{1,2}-d{1,2}$/; 
var str = '2008-8-8'; 
var str2 = '2008-08-08'; 
var str3 = '08-08-2008'; 
var str4 = '2008 08 08'; 
document.write(testReg(reg,str)+'lt;br /gt;'); 
document.write(testReg(reg,str2)+'lt;br /gt;'); 
document.write(testReg(reg,str3)+'lt;br /gt;'); 
document.write(testReg(reg,str4)+'lt;br /gt;'); 
lt;/scriptgt; 

第二种格式:来源:求一正则表达式

yyyy-mm-dd


yyyy/mm/dd

用“或”简单地修改一下就行了。

/^d{4}(-|/)d{1,2}(-|/)d{1,2}$/ 去掉文件的后缀名

来源:求一个正则

www.abc.com/dc/fda.asp变为www.abc.com/dc/fda

如果文件后缀已知的话这个问题就非常简单了,正则如下:

/.asp$/ 匹配最后的.asp而已,测试代码如下:

lt;script type="text/javascript"gt; 
function delAspExtension(str){ 
var reg = /.asp$/; 
return str.replace(reg,''); 
} 
var str = 'www.abc.com/dc/fda.asp'; 
document.write(delAspExtension(str)+'lt;br /gt;'); 
lt;/scriptgt; 

如果文件名未知的话就用这个正则:/.w+$/,测试代码如下:

lt;script type="text/javascript"gt; 
function delExtension(str){ 
var reg = /.w+$/; 
return str.replace(reg,''); 
} 
var str = 'example.com/dc/fda.asp'; 
document.write(delExtension(str)+'lt;br /gt;'); 
var str2 = 'test/regular/fda.do'; 
document.write(delExtension(str2)+'lt;br /gt;'); 
var str3 = 'example.com/dc/fda.strange_extension'; 
document.write(delExtension(str3)+'lt;br /gt;'); 
lt;/scriptgt; 

验证邮箱的正则表达式

来源:找javascript写的表单检查代码!

fuchangxi的正则:

/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/ 开始必须是一个或者多个单词字符或者是-,加上@,然后又是一个或者多个单词字符或者是-。然后是点“.”和单词字符和-的组合,可以有一个或者多个组合。

lt;script type="text/javascript"gt; 
function isEmail(str){ 
var reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/; 
return reg.test(str); 
} 
var str = 'test@hotmail.com'; 
document.write(isEmail(str)+'lt;br /gt;'); 
var str2 = 'test@sima.vip.com'; 
document.write(isEmail(str2)+'lt;br /gt;'); 
var str3 = 'te-st@qq.com.cn'; 
document.write(isEmail(str3)+'lt;br /gt;'); 
var str4 = 'te_st@sima.vip.com'; 
document.write(isEmail(str4)+'lt;br /gt;'); 
var str5 = 'te.._st@sima.vip.com'; 
document.write(isEmail(str5)+'lt;br /gt;'); 
lt;/scriptgt; 

我不太了解邮箱的具体规则。感觉这个正则比较简单,EMAIL校验 正则 讨论 求解里有比较详细的邮箱正则讨论。

匹配源代码中的链接

来源:正则

能够匹配HTML代码中链接的正则。

原帖正则:

/lt;a href=".+#63;"gt;.+#63;lt;/agt;/g 感觉有点严格,首先要lt;a href="".+#63;"gt;有,而且href属性可以是一个或者多个除换行外任意字符(非贪婪)。后面是.+#63;lt;/agt;,一个或者多个除换行外任意字符(非贪婪),再加上结束标签。

有个问题,如果a的起始标签最后有空格,或者除了href还有其它属性的话,上面的正则就不能匹配这个链接了。

例如:

lt;a href="asdfs" gt;……多了个空格。

lt;a id="xx" href=""asdfs"gt;……前面有属性。

……

重写正则:

/lt;as(s*w*#63;=".+#63;")*(s*href=".+#63;")(s*w*#63;=".+#63;")*s*gt;[sS]*#63;lt;/agt;/ 思路如下:首先要有lt;a和一个空格。/lt;as/

第一个(s*w*#63;=".+#63;")*

可以匹配一个属性,属性前面可能有或者没有多余的空格,用s*匹配;属性名肯定是单词字符,用w*#63;匹配;=".+#63;"就是匹配属性值了非换行字符若干个;整个括号外面加个*表示可能有任意多个属性。

(s*href=".+#63;")

匹配href,它也是一个属性,所以只要把上面子正则表达式中的w修改为href=就行了。

(s*w*#63;=".+#63;")*重复第一个子正则表达式,再次接受任意个属性。

s*gt;,属性最后再加上若干个空格和gt;。

[sS]*#63;,链接的文字,可能有任何字符组成,若干个,非贪婪。

lt;/agt;最后是结束标签。

补充:属性名和=之间,以及=和属性值之间也可能有空格。所以要再加上几个s*。

最后的实例代码如下:

lt;script type="text/javascript"gt; 
function findLinks(str){ 
var reg = /lt;as(s*w*#63;s*=s*".+#63;")*(s*hrefs*=s*".+#63;")(s*w*#63;s*=s*".+#63;") 
*s*gt;[sS]*#63;lt;/agt;/g; 
var arr = str.match(reg); 
for(var i=0;ilt;arr.length;i++){ 
//alert(arr[i]); 
document.write('link:'+arr[i]+'lt;br /gt;'); 
} 
} 
var str = 'lt;pgt;测试链接:lt;a id = "test" href="http://bbs.blueidea.com" title="无敌"gt;经典论坛 
lt;/agt;lt;/pgt;lt;a#63; href = "http://www.blueidea.com/"#63; gt;蓝色理想lt;/agt;'; 
var arr = findLinks(str); 
lt;/scriptgt; 

会把所有的链接在页面直接显示出来。注意,

本帖遗留问题:如何执行从右到左的匹配。貌似JS或者VBS没有提供这个功能2、JS或者VBS不支持 后行断言。。用什么方法实现这个功能。

匹配链接的文字
来源:求一正则#63;

代码:lt;a href="#gt;这里要保存lt;/agt;,只保存链接的文本内容,标签信息删掉。

前面写过一个匹配链接的正则:

/lt;as(s*w*#63;=".+#63;")*(s*href=".+#63;")(s*w*#63;=".+#63;")*s*gt;[sS]*#63;lt;/agt;/ 不过我们需要捕获的是文字内容,所以需要做一定的修改。第一步就是在所有的括号内都加上#63;:表示不捕获。第二步就是再多加一个括号放在[sS]*#63;两侧,这样就可以捕获到链接的文字内容了。最后正则如下:

/lt;as(#63;:s*w*#63;s*=s*".+#63;")*(#63;:s*hrefs*=s*".+#63;")(#63;:s*w*#63;s*=s*".+#63;")*s*gt;([sS]*#63;)lt;/agt;/

(编辑:常州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读