JavaScript中常用的正则表达式日常整理(全)
|
/^(([a-z]+s+)|(s+[a-z]+))[a-zs]*$/i 英文开头加空格,或者是空格开头加英文,后面可以是英文或者空格。测试代码如下:
lt;script type="text/javascript"gt;
function istrue(str){
var reg=/^(([a-z]+s+)|(s+[a-z]+))[a-zs]*$/i;
return reg.test(str);
}
var str#63; = 'asdf';
var str2 = 'sadf sdf';
var str3 = 'asdf ';
document.write(istrue(str)+'lt;br /gt;');
document.write(istrue(str2)+'lt;br /gt;');
document.write(istrue(str3)+'lt;br /gt;');
lt;/scriptgt;
利用这个思路也可以实现英文空格英文,英文单词多于两个的匹配。同样,也可以把英文字母换成单词字符w。 显示或者保存正则表达式匹配的部分内容 13588888333 要求,要求只匹配135开头的电话,但是匹配结果只保留135后面的数字。 由于JavaScript里的正则不支持(#63;=xx)xxx的模式,只支持xxx(#63;=xx)的模式。所以只能将135后面的内容作为一个子正则表达式匹配的内容,然后再在后面引用。 Carl给出的函数如下:
function f(phoneNumber) {
var pattern = /^(135)(d{8})$/;
if(pattern.test(phoneNumber))
return phoneNumber.replace(pattern,"$2");
else
return "不是135打头的手机号码!";
}
/^(135)(d{8})$/ 正则中,135作为开头表示第一个子正则表达式,第二个括号内的子正则表达式则匹配后面的8个数字,然后在replace中使用$2就可以引用这个子正则表达式匹配的内容了。测试代码如下:
lt;script type="text/javascript"gt;
function f(phoneNumber) {
var pattern = /^(135)(d{8})$/;
if(pattern.test(phoneNumber))
return phoneNumber.replace(pattern,"$2");
else
return "不是135打头的手机号码!";
}
var arr = new Array(
"13588888333",
"13658447322",
"13558885354",
"13587774654",
"13854554786"
);
for(var i = 0; i lt; arr.length; i++)
document.write(f(arr[i])+'lt;br /gt;');
lt;/scriptgt;
正则表达式替换变量 来源:求教正则 有一个数组: var _A = ['A','B','C','D']; 有一个有“变量”的字符串。 var _B = 'lt;ulgt;lt;ligt;$0$lt;/ligt;lt;ligt;$1$lt;/ligt;lt;ligt;$2$lt;/ligt;lt;ligt;$3$lt;/ligt;lt;/ulgt;'; 说是变量,其实只是字符串中的特殊字符,例如$0$,就称这个为伪变量吧。 最后的要求就是使用正则获得下面这样一个字符串: _C = 'lt;ulgt;lt;ligt;Alt;/ligt;lt;ligt;Blt;/ligt;lt;ligt;Clt;/ligt;lt;ligt;Dlt;/ligt;lt;/ulgt;'; IamUE给出了代码:
lt;script type="text/javascript"gt;
var _A = ['A','B','C','D'];
var _B = 'lt;ulgt;lt;ligt;$0$lt;/ligt;lt;ligt;$1$lt;/ligt;lt;ligt;$2$lt;/ligt;lt;ligt;$3$lt;/ligt;lt;/ulgt;';
var reg=/$d+$/ig;
C=_B.replace(reg,function($1){
var indexnum=$1.replace(/$/ig,"");
if (indexnumlt;_A.length)
{return _A[indexnum];}
else{return ""}
});
alert(C);
lt;/scriptgt;
代码分析:看到代码之后感觉有点晕,首先,正则reg中没有任何的括号,应该是没有捕获内容的,那么后面怎么又使用$1了引用了呢?通过alert测试,发现它是整个正则匹配的内容,而且不一定要写作$1,可以写为$0,甚至是写为x都没关系,它总是整个匹配。 第一次,$1匹配到_B中的“$0$”,匿名函数中将它的$去掉,变成了0,检查是否越界之后,用这个0作为下标去访问数组_A。 由于正则reg定义了g属性,所以会继续替换$1$、$2$等等。步骤都和上面一样。 正则替换指定属性中的文本 来源:怎样用正则来查找替换? 有如下代码:
lt;td align="center"gt;lt;img src="../photo/ccg/thumbnails/O'Malley's West_jpg.gif" border="0" onClick="MM_openBrWindow('../photo/ccg/pages/O'Malley's West_jpg.htm','BE','width=386,height=306')"gt;lt;brgt;
O'Malley's Westlt;/tdgt;
要求将所有onclick属性中的'替换成',也就是将单引号转义。 首先,需要匹配onclick属性: /onclicks*=s*".+#63;"/ig 然后再将所有的'都替换成'就可以了。 将阿拉伯数字替换为中文大写形式 来源:正则问题 将123替换成壹贰叁。 只要匹配一个数字就可以了,测试代码如下(如果显示为乱码就调整一下浏览器的字符编码):
function replaceReg(reg,str){
return str.replace(reg,function(m){return arr[m];})
}
arr=new Array("零","壹","贰","叁","肆","伍","陆","柒","捌","玖");
var reg = /d/g;
var str = '13889294444';
var str2 = '12889293333';
var str3 = '23445567';
document.write(replaceReg(reg,str)+'lt;br /gt;');
document.write(replaceReg(reg,str2)+'lt;br /gt;');
document.write(replaceReg(reg,str3)+'lt;br /gt;');
替换文本中的URL为链接 来源:求一链接替换正则 将一个用户输入的一段文字中的url替换成可以点击的link地址。例如:http://www.blueidea.com可以替换成 [url]http://www.cctv.com[/url] 或lt;a href="http://www.cctv.com"gt;http://www. blueidea.comlt;/agt;. 这个正则的关键就在于匹配链接,匹配之后,在两边加上a标签和属性不是问题。 /http://[w-]*(.[w-]*)+/ig 首先匹配http://。 [w-]*是可能的www和bbs等。 .[w-]*匹配.xxx形式,至少有一个。 (编辑:佛山站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |



