一、什么是正则(有什么用?)
正则表达式:用来操作字符串,按照一定的规则去匹配字符串
正则表达式存在的作用,就是为规范用户输入的账号,密码,手机号,身份证号等一些数据.
二、正则表达式创建方式(两种)
第一种方式:
var 对象名 = new RegExp(参数1, 参数2);
参数1: 匹配的规则,必须是字符串类型
参数2: 可以省略,属性可选值,用来设置匹配的范围.
如果我们想要匹配字符串是否符合规则,必须使用正则表达式对象来调用test函数.
用法: 正则对象.test(字符串);
test函数是用来判断字符串是否满足正则表达是的规则,如果满足就返回true.如果不符合就返回false.
第二种方式:
创建正则对象常用的方式----语法糖 简洁方式创建对象
var 正则对象 = /参数1/参数2;
参数1:匹配的规则
参数2:可以省略,属性可选值,用来设置匹配范围
参数2的可选值:
i 不区分大小写进行匹配
g 全局匹配,即使匹配到对应内容,也会继续往后匹配,一直的字符串结束为止.
m 多行搜索
三、匹配规则:
1.普通字符串匹配规则
例如: /jing/ /el/ /see/ /123/ 等
字符串中只有包含正则对象中的参数1, 就是合法字符串!
2.特殊字符的匹配含义
\n 换行
\t tab键
\r 回车键enter
\d 数字0-9
[0123456789] 数字0-9
[0-9] 数字0-9
\D 也可[^0123456789] 非数字
\w 字母,数字,下划线
\W 非(字母,数字,下划线)
\s 空白(例如空格 换行 tab键)
\S 非空白
. 也可 [^\n] 除了\n之外的其他字符
[] 用来匹配字符串对象中是否出现过[]中的字符串,如果出现则匹配成功,返回true.反之匹配失败,返回false
[^] 用来匹配除了[]中以外的字符
^ 单独使用,不放在[]中. 而是放在匹配规则的开头,就是表示必须以某某开头.
^[] 匹配以[]中出现的字符为开头
| 或者
$ 必须以某某结尾
四、特殊的字符对应的正则表达式
1.选字符 - 横线- 在这代表范围
例如:
[0-9] 类似\d, 其实也可以[3-8] [2-5]
[a-z] 匹配所有小写字母
[A-Z] 匹配所有的大写字母
[0-9a-zA-Z_] 等价于 \w 字母数字下划线
特殊的:匹配中文汉字
[\u4e00-\u9fa5]
非汉字
[^\u4e00-\u9fa5]
五、正则表达式相关函数
1.match(正则表达式)
作用:用来匹配该字符串中是否含有符合匹配规则的字符串. 返回值是一个数组,每个符合条件的字符串作为数字的一个元素.
而且一般搭配 g 全局查找
2.search(正则表达式) 按照正则匹配来查找字符串
作用:只要匹配到符合规则的字符串,就会将该字符串的开始下标返回.如果没有找到符合规则的字符串就返回-1. 所以返回值是下标或者是-1
不需要全局查找!!!!!!!!!
3.split(参数) 字符串分割成数组
其参数可以放普通字符串,也可以设置正则表达式
作用:就是按照特定的字符 将字符串分割成数组并返回! 返回值是数组!
4.replace(正则表达式, 字符串)
作用:但凡符合正则匹配规则的,都替换掉!!
一般搭配上g 全局查找!
六、量词
{n} 连续重复出现至少n次
{m,n} 连续重复出现m到n次
+ 相当于{1} 至少出现1次,到无穷大次
* 相当于{0,∞} 出现0次到无限次
? 相当于{0, 1} 出现0次或者1次
七、定位符
^ 以某某字符开头
$ 以某某字符结尾
\b 匹配到单词的边界