当前位置: 编程技术>其它
经典JavaScript正则表达式实战(附pdf)
来源: 互联网 发布时间:2014-10-17
本文导语: 关于测试代码 本文不是使用Dreamweaver编辑,以下测试代码可能已经在赋值粘贴的过程做了一些调整,可能执行失效。可以参看本文的pdf版本。 匹配结尾的数字 如 代码如下: 30CAC0040 取出40 3SFASDF92 取出92 正则如下:/d+$/g 统一...
关于测试代码
本文不是使用Dreamweaver编辑,以下测试代码可能已经在赋值粘贴的过程做了一些调整,可能执行失效。可以参看本文的pdf版本。
匹配结尾的数字
如
30CAC0040 取出40
3SFASDF92 取出92
正则如下:/d+$/g
统一空格个数
字符串内字符键有空格,但是空格的数量可能不一致,通过正则将空格的个数统一变为一个。
例如:蓝 色 理 想
变成:蓝 色 理 想
aobert的正则:
var str="蓝 色 理 想"
var reg=/s+/g
str = str.replace(reg," ")
document.write(str)
判断字符串是不是由数字组成
来源:有没有简单的方法判断字符串由数字组成?
这个正则比较简单,写了一个测试
function isDigit(str){
var reg = /^d*$/;
return reg.test(str);
}
var str = "7654321";
document.write(isDigit(str));
var str = "test";
document.write(isDigit(str));
电话号码正则
:求一个验证电话号码的JS正则
/^d{3,4}-d{7,8}(-d{3,4})?$/区号必填为3-4位的数字,区号之后用“-”与电话号码连接
^d{3,4}-电话号码为7-8位的数字
d{7,8}分机号码为3-4位的数字,非必填,但若填写则以“-”与电话号码相连接
(-d{3,4})?手机号码正则表达式
正则验证手机号,忽略前面的0,支持130-139,150-159。忽略前面0之后判断它是11位的。
cloeft的正则:
/^0*(13|15)d{9}$/^0*匹配掉开头任意数量的0。
发布的手机号码
function checkMobile(){
var sMobile = document.mobileform.mobile.value
if(!(/^1[3|4|5|8][0-9]d{4,8}$/.test(sMobile))){
alert("不是完整的11位手机号或者正确的手机号前七位");
document.mobileform.mobile.focus();
return false;
}
}
由于手机号码是13任意数字9位,和15任意数字9位,所以可以用(13|15)d{9}匹配。
测试代码如下:
function testReg(reg,str){
return reg.test(str);
}
var reg =/^1[3|4|5|8][0-9]d{4,8}$/;
var str = '13889294444';
var str2 = '12889293333';
var str3 = '23445567';
document.write(testReg(reg,str)+'
');
document.write(testReg(reg,str2)+'
');
document.write(testReg(reg,str3)+'
');
使用正则表达式实现删除字符串中的空格:
来源:请问js中有没有去掉空格的函数
代码以及测试代码如下:
//删除字符串两侧的空白字符。
function trim(str){
return str.replace(/^s+|s+$/g,'');
}
//删除字符串左侧的空白字符。
function ltrim(str){
return str.replace(/^s+/g,'');
}
//删除字符串右侧的空白字符。
function rtrim(str){
return str.replace(/s+$/g,'');
}
//以下为测试代码
var trimTest = " 123456789 ";
//前后各有一个空格。
document.write('length:'+trimTest.length+'
');
//使用前
document.write('ltrim length:'+ltrim(trimTest).length+'
');
//使用ltrim后
document.write('rtrim length:'+rtrim(trimTest).length+'
');
//使用rtrim后
document.write('trim length:'+trim(trimTest).length+'
');
//使用trim后
测试的结果如下:
length:11
ltrim length:10
rtrim length:10
trim length:9限制文本框只能输入数字和小数点等等
来源:文本框输入限制的问题????
只能输入数字和小数点
var reg = /^d*.?d{0,2}$/开头有若干个数字,中间有0个或者一个小数点,结尾有0到2个数字。
只能输入小写的英文字母和小数点,和冒号,正反斜杠(:./)
var reg = /[a-z./\:]+/;a-z包括了小写的英文字母,.是小数点,/和\分别是左右反斜线,最后是冒号。整个组成一个字符集和代码任一均可,最后在加上+,1或者多个。
替换小数点前内容为指定内容
请问 怎么把这个字符串的小数点前面的字符替换为我自定义的字符串啊?
例如:infomarket.php?id=197 替换为 test.php?id=197
应该可以把第一个点“.”之前的所有单词字符替换为test就可以了。我写的正则如下:
var str = "infomarket.php?id=197";
var reg = /^w*/ig;
//匹配字符串开头的任意个单词字符
str = str.replace(reg,'test');
document.write(str);
原帖的有点复杂,没太看明白。
只匹配中文的正则表达式
前两天看的《JavaScript开发王》里恰好有中文的unicode范围,正则如下:
/[u4E00-u9FA5uf900-ufa2d]/写了一个简单的测试,会把所有的中文替换成“哦”。
var str = "有中文?and English.";
var reg = /[u4E00-u9FA5uf900-ufa2d]/ig;
str = str.replace(reg,'哦');
document.write(str);
返回字符串的中文字符个数
一般的字符长度对中文和英文都是不分别的 如JS里的length,那么如何返回字符串中中文字符的个数呢?guoshuang老师在原帖中给出了解决方案,我又没看懂……
不过我自己也想到了一个办法:先去掉非中文字符,再返回length属性。函数以及测试代码如下:
function cLength(str){
var reg = /[^u4E00-u9FA5uf900-ufa2d]/g;
//匹配非中文的正则表达式
var temp = str.replace(reg,'');
return temp.length;
}
var str = "中文123";
document.write(str.length+'
');
document.write(cLength(str));
结果:
5
2中文两个,数字三个,正确。
下面的测试也正确。
var str = "中文123tets@#!#%$#[][{}";
document.write(str.length+'
');
document.write(cLength(str));
正则表达式取得匹配IP地址前三段
来源:如何用正则取IP前3段
192.168.118.101,192.168.118.72, 192.168.118.1都替换成:192.168.118
只要匹配掉最后一段并且替换为空字符串就行了,正则如下:
/.d{1,3}$/匹配结尾的.n,.nn或者.nnn。
测试代码如下:
function replaceReg(reg,str){
return str.replace(reg,'')
}
var reg = /.d{1,3}$/;
var str = '192.168.118.101';
var str2 = '192.168.118.72';
var str3 = '192.168.118.1';
document.write(replaceReg(reg,str)+'
');
document.write(replaceReg(reg,str2)+'
');
document.write(replaceReg(reg,str3)+'
');
相似的有,这个帖子里有一个验证IP地址的方法:求检验MAC地址的正则表达例子
匹配
本文不是使用Dreamweaver编辑,以下测试代码可能已经在赋值粘贴的过程做了一些调整,可能执行失效。可以参看本文的pdf版本。
匹配结尾的数字
如
代码如下:
30CAC0040 取出40
3SFASDF92 取出92
正则如下:/d+$/g
统一空格个数
字符串内字符键有空格,但是空格的数量可能不一致,通过正则将空格的个数统一变为一个。
例如:蓝 色 理 想
变成:蓝 色 理 想
aobert的正则:
代码如下:
var str="蓝 色 理 想"
var reg=/s+/g
str = str.replace(reg," ")
document.write(str)
判断字符串是不是由数字组成
来源:有没有简单的方法判断字符串由数字组成?
这个正则比较简单,写了一个测试
代码如下:
function isDigit(str){
var reg = /^d*$/;
return reg.test(str);
}
var str = "7654321";
document.write(isDigit(str));
var str = "test";
document.write(isDigit(str));
电话号码正则
:求一个验证电话号码的JS正则
代码如下:
/^d{3,4}-d{7,8}(-d{3,4})?$/区号必填为3-4位的数字,区号之后用“-”与电话号码连接
^d{3,4}-电话号码为7-8位的数字
d{7,8}分机号码为3-4位的数字,非必填,但若填写则以“-”与电话号码相连接
(-d{3,4})?手机号码正则表达式
正则验证手机号,忽略前面的0,支持130-139,150-159。忽略前面0之后判断它是11位的。
cloeft的正则:
代码如下:
/^0*(13|15)d{9}$/^0*匹配掉开头任意数量的0。
发布的手机号码
代码如下:
function checkMobile(){
var sMobile = document.mobileform.mobile.value
if(!(/^1[3|4|5|8][0-9]d{4,8}$/.test(sMobile))){
alert("不是完整的11位手机号或者正确的手机号前七位");
document.mobileform.mobile.focus();
return false;
}
}
由于手机号码是13任意数字9位,和15任意数字9位,所以可以用(13|15)d{9}匹配。
测试代码如下:
代码如下:
function testReg(reg,str){
return reg.test(str);
}
var reg =/^1[3|4|5|8][0-9]d{4,8}$/;
var str = '13889294444';
var str2 = '12889293333';
var str3 = '23445567';
document.write(testReg(reg,str)+'
');
document.write(testReg(reg,str2)+'
');
document.write(testReg(reg,str3)+'
');
使用正则表达式实现删除字符串中的空格:
来源:请问js中有没有去掉空格的函数
代码以及测试代码如下:
代码如下:
//删除字符串两侧的空白字符。
function trim(str){
return str.replace(/^s+|s+$/g,'');
}
//删除字符串左侧的空白字符。
function ltrim(str){
return str.replace(/^s+/g,'');
}
//删除字符串右侧的空白字符。
function rtrim(str){
return str.replace(/s+$/g,'');
}
//以下为测试代码
var trimTest = " 123456789 ";
//前后各有一个空格。
document.write('length:'+trimTest.length+'
');
//使用前
document.write('ltrim length:'+ltrim(trimTest).length+'
');
//使用ltrim后
document.write('rtrim length:'+rtrim(trimTest).length+'
');
//使用rtrim后
document.write('trim length:'+trim(trimTest).length+'
');
//使用trim后
测试的结果如下:
length:11
ltrim length:10
rtrim length:10
trim length:9限制文本框只能输入数字和小数点等等
来源:文本框输入限制的问题????
只能输入数字和小数点
代码如下:
var reg = /^d*.?d{0,2}$/开头有若干个数字,中间有0个或者一个小数点,结尾有0到2个数字。
只能输入小写的英文字母和小数点,和冒号,正反斜杠(:./)
代码如下:
var reg = /[a-z./\:]+/;a-z包括了小写的英文字母,.是小数点,/和\分别是左右反斜线,最后是冒号。整个组成一个字符集和代码任一均可,最后在加上+,1或者多个。
替换小数点前内容为指定内容
请问 怎么把这个字符串的小数点前面的字符替换为我自定义的字符串啊?
例如:infomarket.php?id=197 替换为 test.php?id=197
应该可以把第一个点“.”之前的所有单词字符替换为test就可以了。我写的正则如下:
代码如下:
var str = "infomarket.php?id=197";
var reg = /^w*/ig;
//匹配字符串开头的任意个单词字符
str = str.replace(reg,'test');
document.write(str);
原帖的有点复杂,没太看明白。
只匹配中文的正则表达式
前两天看的《JavaScript开发王》里恰好有中文的unicode范围,正则如下:
/[u4E00-u9FA5uf900-ufa2d]/写了一个简单的测试,会把所有的中文替换成“哦”。
代码如下:
var str = "有中文?and English.";
var reg = /[u4E00-u9FA5uf900-ufa2d]/ig;
str = str.replace(reg,'哦');
document.write(str);
返回字符串的中文字符个数
一般的字符长度对中文和英文都是不分别的 如JS里的length,那么如何返回字符串中中文字符的个数呢?guoshuang老师在原帖中给出了解决方案,我又没看懂……
不过我自己也想到了一个办法:先去掉非中文字符,再返回length属性。函数以及测试代码如下:
代码如下:
function cLength(str){
var reg = /[^u4E00-u9FA5uf900-ufa2d]/g;
//匹配非中文的正则表达式
var temp = str.replace(reg,'');
return temp.length;
}
var str = "中文123";
document.write(str.length+'
');
document.write(cLength(str));
结果:
5
2中文两个,数字三个,正确。
下面的测试也正确。
代码如下:
var str = "中文123tets@#!#%$#[][{}";
document.write(str.length+'
');
document.write(cLength(str));
正则表达式取得匹配IP地址前三段
来源:如何用正则取IP前3段
192.168.118.101,192.168.118.72, 192.168.118.1都替换成:192.168.118
只要匹配掉最后一段并且替换为空字符串就行了,正则如下:
/.d{1,3}$/匹配结尾的.n,.nn或者.nnn。
测试代码如下:
代码如下:
function replaceReg(reg,str){
return str.replace(reg,'')
}
var reg = /.d{1,3}$/;
var str = '192.168.118.101';
var str2 = '192.168.118.72';
var str3 = '192.168.118.1';
document.write(replaceReg(reg,str)+'
');
document.write(replaceReg(reg,str2)+'
');
document.write(replaceReg(reg,str3)+'
');
相似的有,这个帖子里有一个验证IP地址的方法:求检验MAC地址的正则表达例子
匹配
- 与
- 之间的内容
- safsf
- safsf
- safsf
用正则可以得到
- 起到下个
- 之间的内容。
正则如下:
代码如下:
/
- [sS]+?
- /i
首先匹配两侧的ul标签,中间的[sS]+?可以匹配一个或者多个任意字符,一定要非贪婪,否则会匹配
- safsf
- safsf
- 。
用正则表达式获得文件名
c:imagestupian06.jpg
可能是直接在盘符根目录下,也可能在好几层目录下,要求替换到只剩文件名。
xlez的正则如下:
代码如下:
/[^\/]*[\/]+/g
首先匹配非左右斜线字符0或多个,然后是左右斜线一个或者多个。形如“xxx/”或者“xxx”或者“/”或者“”
函数以及测试代码:
代码如下:
function getFileName(str){
var reg = /[^\/]*[\/]+/g;
//xxx或者是xxx/
str = str.replace(reg,'');
return str;
}
var str = "c:\images\tupian\006.jpg";
document.write(getFileName(str)+'
');
var str2 = "c:/images/tupian/test2.jpg";
document.write(getFileName(str2));
注意,需要转义。
绝对路径变相对路径
来源:讨论一个正则
将转换为:。
其中网址可能改变,例如http://localhost等等。
cloudchen的正则:
/http://[^/]+/首先是http://,然后[^/]+找过1个或者多个非/字符,因为遇到第一个/表示已经到目录了,停止匹配。
测试代码如下:
代码如下:
var str = '';
var reg = /http://[^/]+/;
str = str.replace(reg,"");
alert(str)
用户名正则
用于用户名注册,,用户名只 能用 中文、英文、数字、下划线、4-16个字符。
hansir和解决方案弄成正则:
代码如下:
/^[u4E00-u9FA5uf900-ufa2dw]{4,16}$/
中文字符或者单词字符,4到16个。实现4到16结成到正则里的关键就是开始^和结束$,这就等于整个字符串只能有这些匹配的内容,不能有多余的。
函数和测试代码如下:
代码如下:
function isEmail(str){
var reg = /^[u4E00-u9FA5uf900-ufa2dw]{4,16}$/;
return reg.test(str);
}
var str = '超级无敌用户名regExp';
var str2 = '捣乱的@';
var str3 = '太短'
var str4 = '太长longlonglonglonglonglonglonglong'
document.write(isEmail(str)+'
');
document.write(isEmail(str2)+'
');
document.write(isEmail(str3)+'
');
document.write(isEmail(str4)+'
');
匹配英文地址
来源:-求助- 正则问题
规则如下:
包含 "点", "字母","空格","逗号","数字",但开头和结尾不能是除字母外任何字符。
[.a-zA-Zs,0-9]这个字符集就实现了字母,空格,逗号和数字。最终正则如下:
/^[a-zA-Z][.a-zA-Zs,0-9]*?[a-zA-Z]+$/
开头必须有字母,结束也必须是一个以上字母。测试代码如下:
代码如下:
function testReg(reg,str){
return reg.test(str);
}
var reg = /^[a-zA-Z][.a-zA-Zs,0-9]*?[a-zA-Z]+$/;
var str = 'No.8,ChangAn Street,BeiJing,China';
var str2 = '8.No,ChangAn Street,BeiJing,China';
var str3 = 'No.8,ChangAn Street,BeiJing,China88';
document.write(testReg(reg,str)+'
')
document.write(testReg(reg,str2)+'
')
document.write(testReg(reg,str3)+'
')
正则匹配价格
价格的格式应该如下:
开头数字若干位,可能有一个小数点,小数点后面可以有两位数字。hansir给出的对应正则如下:
/^(d*.d{0,2}|d+).*$/
hansir给出的测试代码如下:
代码如下:
无标题文档
function checkPrice(me){
if(!(/^(?:d+|d+.d{0,2})$/.test(me.value))){
me.value = me.value.replace(/^(d*.d{0,2}|d+).*$/,'$1');
}
}
身份证号码的匹配
来源:关于正则的,大家帮帮忙,急,在线等
身份证号码可以是15位或者是18位,其中最后一位可以是X。其它全是数字,正则如下:
/^(d{14}|d{17})(d|[xX])$/开头是14位或者17位数字,结尾可以是数字或者是x或者是X。
测试代码如下:
代码如下:
function testReg(reg,str){
return reg.test(str);
}
var reg = /^(d{14}|d{17})(d|[xX])$/;
var str = '123456789012345';//15位
var str2 = '123456789012345678';//18位
var str3 = '12345678901234567X';//最后一位是X
var str4 = '1234';//位数不对
document.write(testReg(reg,str)+'
');
document.write(testReg(reg,str2)+'
');
document.write(testReg(reg,str3)+'
');
document.write(testReg(reg,str4)+'
');
要求文本有指定行数
匹配至少两行的字符串,每行都为非空字符。
只要匹配到[nr]就表示有换行了,再保证换行的两段都不是空字符就可以了。正则如下:
/S+?[nr]S+?/i
这个正则的应用应该是用在textarea里,如果是如下要求:可以支持所有字符,中间可带空格,可以包括英文、数字、中文、标点
这样的话,只要针对空格再改一下就行了。(按照非空的要求,上面有不能匹配“字符+空格+换行+字符”的字符串)。修改如下:
/S+?s*?[nr]s*?S+?/i
单词首字母大写
来源:求个正则,处理英文单词或词组的
每单词首字大写,其他小写。如blue idea转换为Blue Idea,BLUE IDEA也转换为Blue Idea
cloeft的正则:
代码如下:
/b(w)|s(w)/g
所谓“首字母”包括两种情况:第一种是边界(开头)的单词字符,一种是空格之后的新单词的第一个字母。测试代码如下:
代码如下:
function replaceReg(reg,str){
str = str.toLowerCase();
return str.replace(reg,function(m){return m.toUpperCase()})
}
var reg = /b(w)|s(w)/g;
var str = 'blue idea';
var str2 = 'BLUE IDEA';
var str3 = 'Test n str is no good!';
var str4 = 'final test';
document.write(replaceReg(reg,str)+'
');
document.write(replaceReg(reg,str2)+'
');
document.write(replaceReg(reg,str3)+'
');
document.write(replaceReg(reg,str4)+'
');
正则验证日期格式
yyyy-mm-dd格式
正则如下:
代码如下:
/^d{4}-d{1,2}-d{1,2}$/
4位数字,横线,1或者2位数字,再横线,最后又是1或者2位数字。
测试代码如下:
代码如下:
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)+'
');
document.write(testReg(reg,str2)+'
');
document.write(testReg(reg,str3)+'
');
document.write(testReg(reg,str4)+'
');
第二种格式:来源:求一正则表达式
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而已,测试代码如下:
代码如下:
function delAspExtension(str){
var reg = /.asp$/;
return str.replace(reg,'');
}
var str = 'www.abc.com/dc/fda.asp';
document.write(delAspExtension(str)+'
');
如果文件名未知的话就用这个正则:/.w+$/,测试代码如下:
代码如下:
function delExtension(str){
var reg = /.w+$/;
return str.replace(reg,'');
}
var str = 'example.com/dc/fda.asp';
document.write(delExtension(str)+'
');
var str2 = 'test/regular/fda.do';
document.write(delExtension(str2)+'
');
var str3 = 'example.com/dc/fda.strange_extension';
document.write(delExtension(str3)+'
');
验证邮箱的正则表达式
来源:找javascript写的表单检查代码!
fuchangxi的正则:
/^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+(.[a-zA-Z0-9_-])+/开始必须是一个或者多个单词字符或者是-,加上@,然后又是一个或者多个单词字符或者是-。然后是点“.”和单词字符和-的组合,可以有一个或者多个组合。
代码如下:
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)+'
');
var str2 = 'test@sima.vip.com';
document.write(isEmail(str2)+'
');
var str3 = 'te-st@qq.com.cn';
document.write(isEmail(str3)+'
');
var str4 = 'te_st@sima.vip.com';
document.write(isEmail(str4)+'
');
var str5 = 'te.._st@sima.vip.com';
document.write(isEmail(str5)+'
');
我不太了解邮箱的具体规则。感觉这个正则比较简单,EMAIL校验 正则 讨论 求解里有比较详细的邮箱正则讨论。
匹配源代码中的链接
来源:正则
能够匹配HTML代码中链接的正则。
原帖正则:
/.+?/g感觉有点严格,首先要……前面有属性。
……
重写正则:
/[sS]*?/
思路如下:首先要有。
[sS]*?,链接的文字,可能有任何字符组成,若干个,非贪婪。
最后是结束标签。
补充:属性名和=之间,以及=和属性值之间也可能有空格。所以要再加上几个s*。
最后的实例代码如下:
代码如下:
function findLinks(str){
var reg = /[sS]*?/g;
var arr = str.match(reg);
for(var i=0;i"s]+)/ig第一个括号里的s+w+匹配的是属性名。
然后是=,不用转义。
第二个括号里的[^>"s]+匹配属性值。不匹配>”和空格。这里的引号不用转义。在意思不改变的情况下,稍微改了改,正则如下:
/(s+w+)=([^>"s]+)/ig需要注意的是这个正则不匹配=两边有空格的属性,例如href = xxx。相匹配的话就改成:
/(s+w+)s*=s*([^>"s]+)/ig代码:
str=str.replace(/(?!"s]+)/ig,'$1="$2"');
其中'$1=”$2”'就实现了给属性值添加上双引号。不过ncs指出了这个正则替换的几个问题,一是上面的空格问题,二是如果非标签内部有等号,且前面又恰巧有空白字符的话,它将会被误识别为属性,例如:
test=sd
里面的test=sd也会被匹配。三是如果属性原来使用了单引号,会被再包上一层双引号……
来看看LeXRus前辈的新正则替换方法:
str=str.replace(/(?!"s]+)(?=[^>]*>)/ig,'$1="$2"')
.replace(/"'([^'"]+)'"/ig,'"$1"');先来看第一个正则:
/ (s+w+)s*=s*([^>"s]+)(?=[^>]*>)/ig
结尾新添的(?=[^>]*>)意在解决普通文本中有等号被误识别为属性的问题:
test=sd
就没问题了,但是
test=sd又一个标签
中的test=sd又会被识别为属性。
我觉得改成下面的正则就没问题了:
/(s+w+)s*=s*([^"s]+)(?=[^]*>)/ig
分别在第二个括号的字符集合和最后的反向预查的字符集合中添加了一个)/ig
var reg2 = /"'([^'"]*)'"/ig;
str=str.replace(reg1,'$1="$2"').replace(reg2,'"$1"');
trg.value=str;
}
asfd=asfd
原帖里LeXRus又提出了新问题:
hint=i am lexrus
这样的属性会有问题,不过我感觉不加引号的话,属性值里就不可能有空格,否则会被识别为多个属性了。不过看到最后ncs的回帖我就哭了:
onclick=if(document.forms.length>0)
这样的属性怎么办?大于号会被识别为标签结束……还是分离行为与文档吧。补充一下,其实修补一下正则也可以解决,只要改成如下正则即可:
/(s+w+)s*=s*([^"s]+)(?=[^]*>)/ig就是去掉第二个括号内字符集合里的。最后这个问题也解决。
给table加上tbody
来源:通过正则表达式快速在后加上
有若干table,但是没有tbody。现在需要用正则批量加上。
匹配table结束标签比较简单,在前面加上一个就行了。
但是,匹配table的起始标签有点难度,因为可能有属性。不过之前匹配过链接了,这个也大同小异。
实例table代码如下:
正则:
//g匹配一个就代表标签结束。
之后再replace一下,加上就可以了。
去掉标签的所有属性
来源:正则表达式(Dreamweaver8)
***
变成没有任何属性的
***
思路:非捕获匹配属性,捕获匹配标签,使用捕获结果替换掉字符串。正则如下:
/()/首先,td匹配掉了标签,后面可以用$1引用,后面的若干属性被(?:)匹配掉,而最后匹配的>则可以在后面用$2引用。
示意代码:
str = str.replace(reg,'$1$2');
正则替换特定单词
来源:正则表达式,拒绝几个单词的输入该怎样表达?
要求禁止输入某几个单词,如果拒绝red,yellow,white。这个帖子到时不难,但是让我弄清楚了好几个概念。
第一个,小心字符集合里的“或”
/[^red|yellow|white]/这个正则里的所有或都没有意义,等同于:
/[^redyellowwhite]/意思就是不能含有以下列出的所有字母。
正解:
/red|yellow|white/第二个概念:
只要整个正则匹配成功,无论子正则表达式是否匹配成功,括号都会捕捉。例如
/(red)|(yellow)|(white)/会捕捉到三个结果,尽管实际上最多只可能有一个括号匹配成功。但是只要有一个匹配到了,两外两个也会记录空串。
指定文字高亮显示
来源:如何用正则把网页中的指定的字高亮显示
请教正则表达式:如何替换搜索结果中的关键字为高亮显示?
不劳而获一次,这个子虚乌有前辈已经给出了非常好的解决方案:我直接把代码贴出来了:
代码如下:
function encode(s){
return s.replace(/&/g,"&").replace(//g,">").replace(/([\.*[]()$^])/g,"\$1");
}
function decode(s){
return s.replace(/\([\.*[]()$^])/g,"$1").replace(/>/g,">").replace(//gi,'');
刚开始没反应过来,后来才想起来,这个正则不用区分起始和结束标签。
/]*
匹配到>或者/就结束。
/?>
起始标签或者结束标签的结尾。