正则表达式的利用

正则表达式(regular expression)是一个叙述字符模式之目标。ECMAScript 的
RegExp 类
表示正则表达式,而 String 和 RegExp
都定义了运用正则表达式进行强有力的模式匹配和文件
寻找和替换的函数。
正则表达式主要为此来证实客户端的输入数据。用户填写了表单单击按钮后,表单就见面
深受发送到服务器,在劳动器端通常会因此 PHP、ASP.NET
等服务器脚本对那进展更处理 。
因客户端验证,可以节省大量底劳动器端的系统资源,并且提供再好的用户体验。

 

模式修饰符的可选参数
参 数 含 义
i 忽略大小写
g 全局匹配
m 多尽匹配

 

RegExp 对象的章程
方 法 功 能
test 于字符串中测试模式匹配,返回 true 或 false
exec 在字符串中执匹配搜索,返回结果数组

 

String 对象吃之正则表达式方法
方 法 含 义
match(pattern) 返回 pattern 中的子串或 null
replace(pattern, replacement) 用 replacement 替换 pattern
search(pattern) 返回字符串中 pattern 开始位置
split(pattern) 返回字符串按指定 pattern 拆分的数组

 

RegExp 对象的静态属性
属 性 短 名 含 义
input $_ 当前叫匹配的字符串
lastMatch $& 最后一个匹配字符串
lastParen $+ 最后一对圆括号内之匹配子串
leftContext $` 最后一破匹配前之子串
multiline $* 用于指定是否有的表达式都用于多行的布尔值
rightContext $’ 在上次相当之后的子串

 

RegExp 对象的实例属性
属 性 含 义
global Boolean 值,表示 g 是否曾经安装
ignoreCase Boolean 值,表示 i 是否业已设置
lastIndex 整数,代表下次配合将自哪字符位置上马
multiline Boolean 值,表示 m 是否都安装
Source 正则表达式的源字符串形式

 

 

字符类:单个字符和数字
元字符/元符号 匹配情况
. 匹配除换行符外的任性字符
[a-z0-9] 匹配括号被之字符集中的轻易字符
[^a-z0-9] 匹配任意不以括号中的字符集中之字符
\d 匹配数字
\D 匹配非数字,同[^0-9]相同
\w 匹配字母和数字和_
\W 匹配非字母和数字与_

字符类:空白字符
元字符/元符号 匹配情况
\0 匹配 null 字符
\b 匹配空格字符
\f 匹配上纸字符
\n 匹配换行符
\r 匹配回车字符
\t 匹配制表符
\s 匹配空白字符、空格、制表符和换行符
\S 匹配非空白字符

字符类:锚字符
元字符/元符号 匹配情况
^ 行首匹配
$ 行尾匹配
\A 只来配合配字符串开始处于
\b 匹配单词边界,词在[]内时不行
\B 匹配非单词边界
\G 匹配时摸索的始发位置
\Z 匹配字符串结束处或行尾
\z 只相当配字符串结束处

字符类:重复字符
元字符/元符号 匹配情况
x? 匹配 0 个或 1 个 x
x* 匹配 0 个或自由多单 x
x+ 匹配至少一个 x
(xyz)+ 匹配至少一个(xyz)
x{m,n} 匹配最少 m 个、最多 n 个 x

字符类:替代字符
元字符/元符号 匹配情况
this|where|logo 匹配 this 或 where 或 logo 中随意一个

字符类:记录字符
元字符/元符号 匹配情况
(string) 用于反朝引用的分组
\1 或$1 匹配第一单分组中之情节
\2 或$2 匹配第二个分组中的内容
\3 或$3 匹配第三独分组中之始末

 

贪 婪         惰 性

  •              +?
    ?               ??
    *              *?
    {n}          {n}?
    {n,}         {n,}?
    {n,m}      {n,m}?