JavaScript中常用的正则表达式日常整理(全)
测试代码如下: 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不支持 后行断言。。用什么方法实现这个功能。 匹配链接的文字 代码: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;/ (编辑:PHP编程网 - 黄冈站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |