RegExp正则表达式——查找符合某些复杂规则
创建方式有两种:
1、var reg=/pattern/; 2、var reg=new RegExp('pattren'); pattern为赋值到正则表达式的内容,可以是单引号也可以是双引号
正则表达式的exec方法 即匹配:reg.exec(str); str为要执行正则表达式的目标字符串。pattern为匹配内容 结果:若匹配的内容不属于str目标字符串,则为Null; 若匹配的内容属于str目标字符串,则返回匹配的内容。
匹配检测: reg.test(str); 结果为true | false
pattern(n) 取连续的n个pattern。 pattern(m,n) 表示m个到n个pattern。连续的,有顺序
^pattern表示只匹配字符串的开头。 $pattern则只匹配字符串结尾的字符 。 reg = /^c/; str='维生素c'; reg.exec(str); 结果为null,因为字符串‘维生素c’的开头并不是c,所以匹配失败。
‘.’会匹配字符串中除了换行符n之外的所有字符 例: reg = /./; str='cainiao'; execReg(reg,str); 结果显示,正则匹配到了字符c。
reg = /.+/; str='blueidea——经典论坛 好_。'; execReg(reg,str);
结果是:“blueidea——经典论坛 好_。“也就是说所有的字符都被匹配掉了,包括一个空格,一个下滑线,和一个破折号。
reg = /^b|c.+/; str='cainiao'; execReg(reg,str);
匹配掉整个cainiao。
reg = /^(b|c).+/; str='bbs.blueidea.com'; execReg(reg,str);
结果是整个串bbs.blueidea.com,加上上面的括号后,意思是,如果字符串的开头是b或者c,那么匹配开头的b或者c以及其后的所有的非换行字符。
字符集合[abc] [abc]表示a或者b或者c中的任意一个字符
reg = /^[abc]/; str='bbs.blueidea.com'; execReg(reg,str); 返回结果是b。 reg = /^[abc]/; str='test'; execReg(reg,str); 这次的结果就是null了
a-z],[A-Z],[0-9],分别表示? 小写字母,大写字母,数字
reg = /^[a-zA-Z][a-zA-Z0-9_]+/; str='test'; execReg(reg,str); 结果是整个test,正则的意思是:开头必须是英文字母,后面可以是英文字母或者数字以及下划线。
反字符集合[^abc] ^在正则表达式开始部分的时候表示开头的意思,例如/^c/表示开头是c;但是在字符集合中,它表示的是类似“非“的意思,例如[^abc]就表示不能是a,b或者c中的任何一个。 [^0-9]表示非数字,[^a-z]表示非小写字母,一次类推 …
不记录子正则表达式的匹配结果 使用形如(?:pattern)的正则就可以避免保存括号内的匹配结果 。 例: reg = /^(?:b|c).+/; str='bbs.blueidea.com'; execReg(reg,str); 可以看到返回的结果不再包括那个括号内的子正则表达式多匹配的内容。 (编辑:李大同)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|