元字符后面的量词(用n来代表任一个元字符):
+表示n可重复1~+∞
*表示n可重复0~+∞(*为0时会匹配“”)
?表示n可重复0~1
{x}表示n可重复x个
{x,y}表示n可重复x~y
{x,}表示n可重复x~+∞
/abc
/
表
示
匹
配
a
b
c
且
要
以
这
个
c
结
尾
的
才
可
以
匹
配
/
a
b
c
/表示匹配abc且要以这个c结尾的才可以匹配 /^abc
/表示匹配abc且要以这个c结尾的才可以匹配/abc/表示匹配abc且要以这个a开头以这个c结尾才可以匹配
例题:检查一个字符串首尾是否含有数字。(要理解好题意,其实这的意思是首或尾)
正则表达式的方法:
test()判断str中是否有与表达式匹配的片段结果返回Boolean值
exec()这个方法其实是和正则表达式的属性游标lastIndex相匹配一起用的。且得加上属性g,游标才会自动移位。(注意:游标也可以手动改变的)
下面展示一下没有属性g时的表现:
例题:要匹配AAAA型的样式
补充知识点:
()其实还有一个子表达式的意思,如(a)这就是一个子表达式,当用括号将表达式括起来是表达式的内容会被记录起来以供使用,这个时候我们就可以反向引用它。
字符串的几个方法:
str.search()返回匹配到的位置,若无法匹配则返回-1,且这个方法不管有没有加上属性g结果都是一样的:
str.split()可以按照字符串或正则表达式来分割字符串并把他们存入一个数组中变成一个数组。
**重要的str.replace()第一个参数是要替换的字符串或者可以用正则表达式,第二个参数是要字符串或者用function后返回字符串。
先看一个例子:
例题:现在要把aabb变成bbaa,即使倒过来
例题:把the-first-name变成小驼峰形式:
正向预查(正向断言):
?= 判断后面是否紧接着指定的字符串
?!判断后面是否不接着指定的字符串
正则表达式的匹配遵循贪婪匹配的原则,若不想要贪婪匹配,可以在任意一个量词后面加?即可,如{1,3}?这样就不会按最多的匹配而是按1来匹配。
一个注意的点,在正则中
是
有
意
义
的
想
要
写
出
是有意义的想要写出
是有意义的想要写出得写成$$进行转义。
例题:字符串“aaabbcccd”去重:
最后一个例题:百度14年的一道题:
100000000,用科学计数法变成100,000,000: