没入正题前,先感叹一下,正则表达式,强大。
首先加一个连接,这里比较基础,比较详细,并且大部分我都了解,为了便于翻阅,将url留在这里:
http://www.regexlab.com/zh/regref.htm
我想说的是正则中的正向反向搜索匹配,和括号内非捕获功能。
正反向搜索,我是通过上面的url了解到的,以为自己很了解正则了,原来还是井中之蛙。
1,正向预搜索:\w+(?=xxxxx) , \w+(?!xxxxx)
第一个表达式的意思是\w+后面存在xxxxx
如:
var a = 'ax';
var p = /\w(?=x)/;
p.test(a); => true;
第二个表达式的意思是 匹配\w+后面不存在xxx的部分
var p = /\wa(?!x)/;
2,反向预搜索:\w+(?<=xxxxx) ,\w+(?\w+前面匹配或者不匹配
注明:Javascript中不支持该表达式
3,括号内非捕获 (?:xxxxx)
var p = /a(?:x+)/;
a.match(p); => ['ax']
var p = /a(x+)/;
a.match(p); => ['ax','x']
默认情况下,匹配到括号的字符默认会缓存起来,当加上?:时,服务器默认不缓存,建议不适用正反向引用却必须加括号的情况下,使用这种模式。
4,var name = 'aaa bbb ccc';
var uw=name.replace(/\b\w+\b/g, function(word){
return word.substring(0,1).toUpperCase()+word.substring(1);
});
首先加一个连接,这里比较基础,比较详细,并且大部分我都了解,为了便于翻阅,将url留在这里:
http://www.regexlab.com/zh/regref.htm
我想说的是正则中的正向反向搜索匹配,和括号内非捕获功能。
正反向搜索,我是通过上面的url了解到的,以为自己很了解正则了,原来还是井中之蛙。
1,正向预搜索:\w+(?=xxxxx) , \w+(?!xxxxx)
第一个表达式的意思是\w+后面存在xxxxx
如:
var a = 'ax';
var p = /\w(?=x)/;
p.test(a); => true;
第二个表达式的意思是 匹配\w+后面不存在xxx的部分
var a = 'xxxxaxyyyyay';var a = 'xxxxaxyyyyay';
var p = /\wa(?!x)/;
var p = /\wa(?!x)/;
var a = 'xxxxaxyyyyay';
var p = /\wa(?!x)/;
var a = 'xxxxaxyyyyay';
var p = /\wa(?!x)/;
var a = 'xxxxaxyyyyay';
var p = /\wa(?!x)/;
var a = 'xxxxaxyyyyay';a.match(p); => ['ya']
var p = /\wa(?!x)/;
2,反向预搜索:\w+(?<=xxxxx) ,\w+(?\w+前面匹配或者不匹配
注明:Javascript中不支持该表达式
3,括号内非捕获 (?:xxxxx)
var a = 'xxxxaxyyyyay';var a = 'xxxxaxyyyyay';
var p = /a(?:x+)/;
a.match(p);
var p = /a(?:x+)/;
a.match(p); => ['ax']
var p = /a(x+)/;
a.match(p); => ['ax','x']
默认情况下,匹配到括号的字符默认会缓存起来,当加上?:时,服务器默认不缓存,建议不适用正反向引用却必须加括号的情况下,使用这种模式。
4,var name = 'aaa bbb ccc';
var uw=name.replace(/\b\w+\b/g, function(word){
return word.substring(0,1).toUpperCase()+word.substring(1);
});
从w3school拿来的,让我懂得replace后使用function的同时,也让我了解到\b的匹配模式。
同样\b在上面的url中也有提及。当然我认为还有一种更好的方法
var name = 'aaa bbb ccc d';
var uw=name.replace(/\b(\w)(\w+)?\b/g,function(a,b,c,d){
return b.toUpperCase()+c;
});
经常使用的非匹配
