正则表达式的概念
-
背景:
- 我们在进行数据验证时,需要书写专门的判断代码(各种if-else-if)来验证数据是否输入合法。这样的话随着表单的复杂,那么后续的判断代码只会更多,更难维护。学习正则表达式来进行优化,减少判断代码
-
概念
-
正则表达式本质上是一个特殊的字符串,由专门的语法书写,正则表达式用于描述待验证的数据需要满足的规则。即通过正则表达式来描述待验证的数据需要满足什么样的条件,再配合正则表达式专属的api来验证数据是否满足要求。
-
理解:书写正则表达式,用于确定数据要满足的规则。之后使用api进行验证数据是否满足要求。
-
例子展示
1.书写正则表达式
var reg=/^[0-9]{11}$/;//该正则表达式用于描述数据是否由11个数据构成
2.配合api进行验证
var result = reg.test(待验证的字符串数据);//result 得到的是布尔型数据
- 正则表达式的使用流程
- 分析数据满足的要求,然后书写正则表达式。
- 调用正则表达式提供的api .text()来验证某个字符串数据是否满足要求。
正则表达式书写基础语法
[ ]:组,会匹配组里的任意一个字符
[abc]:匹配abc中任意一个小写字母,即数据中有三个小写字母的其中一个就算匹配成功
- [ 15234]:匹配15234中的任意一个数字。
- [0-9]:特殊写法,任意一个数字。[2-8]:匹配2-8中的任意一个数字。
- [a-z]:特殊写法,匹配任意一个小写字母。
- [A-Z]:特殊写法,匹配任意一个大写字母。
- [a-zA-Z]:匹配任意一个字母。
- [a-zA-Z0-9]:匹配任意一个字母或数字。
- [0-9][0-9]:连续两个数字。
- [0-9A-Za-z][0-9A-Za-z][0-9A-Za-z][0-9A-Za-z]:连续四个字母或数字。
- {m,n}:表示前面的数据最少出现多少次(m),最多出现多少次n。
- [0-9]{1,8}:最少出现一次,最多出现八次数字。
- [0-9]{1,}:最少出现一次数字。
- [0-9]{,8}:最多出现八次数字。
- [0-9]{11}:出现11位固定数字。
^
:以什么开头
^[0-9]
:以数字开头。^[A-Z]
:以大写字母开头。^[a-zA-Z]
:以大写或小写字母开头。$
:以什么结尾
[0-9]$
:以数字结尾。[a-z]$
:以小写字母结尾。^$
:同时使用,则表示匹配整个数据
^[0-9]{11}$
:匹配整个数据是不是11个数据。^[A-Z][a-zA-Z0-9]{5,15}
:以大写字母开头,后面的数据是字母和数字且数据总长度6-16。
正则表达式进阶语法
- 元字符:那些在正则表达式中具有特殊意义的字符。比如
^
、$
- 分类
^
:以什么开头$
:以什么结尾+
:最少出现一次*
:表示前面的数据,可有可无,可多次?
:表示前面的数据,要么没有,要么一次。.
:匹配任意一个非空字符\
: \$,匹配元字符本身。{n,m}
:出现的次数其他语法
\d
:表示数字\w
:等同于[0-9a-zA-Z_]
.表示匹配单词字符
正则表达式模式
概念:正则表达式针对数据的不同验证需求提供不同的模式进行使用。常用模式有三种:
u、i、g
分类
u
:默认模式,指的正则表达式只匹配数据中最近的满足条件的内容g
:全局模式,指的是正则表达式会匹配数据中所有满足条件的内容i
:不区分大小写,正则表达式不区分数据的大小写。