元字符
( [ { \ ^ $ | ) ? * + .
预定义的特殊字符
字符
|
正则
|
描述
|
\t
|
/\t/
|
制表符
|
\n
|
/\n/
|
制表符
|
\r
|
/\r/
|
回车符
|
\f
|
/\f/
|
换页符
|
\a
|
/\a/
|
alert字符
|
\e
|
/\e/
|
escape字符
|
\cX
|
/\cX/
|
与X相对应的控制字符
|
\b
|
/\b/
|
与回退字符
|
\v
|
/\v/
|
垂直制表符
|
\0
|
/\0/
|
空字符
|
字符
|
等同于
|
描述
|
.
|
[^\n\r]
|
除了换行和回车之外的任意字符
|
\d
|
[0-9]
|
数字字符
|
\D
|
[^0-9]
|
非数字字符
|
\s
|
[ \t\n\x0B\f\r]
|
空白字符
|
\S
|
[^ \t\n\x0B\f\r]
|
非空白字符
|
\w
|
[a-zA-Z_0-9]
|
单词字符(所有的字母)
|
\W
|
[^a-zA-Z_0-9]
|
非单词字符
|
代码
|
类型
|
描述
|
?
|
软性量词
|
出现零次或一次
|
*
|
软性量词
|
出现零次或多次(任意次)
|
+
|
软性量词
|
出现一次或多次(至道一次)
|
{n}
|
硬性量词
|
对应零次或者n次
|
{n,m}
|
软性量词
|
至少出现n次但不超过m次
|
{n,}
|
软性量词
|
至少出现n次(+的升级版)
|
贪婪量词,惰性量词与支配性量词
贪婪量词,上面提到的所有简单量词。就像成语中说的巴蛇吞象那样,一口吞下整个字符串,发现吞不下(匹配不了),再从后面一点点吐出来(去掉最后一个字符,再看这时这个整个字符串是否匹配,不断这样重复直到长度为零)
隋性量词,在简单量词后加问号。由于太懒了,先吃了前面第一个字符,如果不饱再捏起多添加一个(发现不匹配,就读下第二个,与最初的组成一个有两个字符串的字符串再尝试匹配,如果再不匹配,再吃一个组成拥有三个字符的字符串……)。其工作方式与贪婪量词相反。
支配性量词,在简单量词后加加号。上面两种都有个不断尝试的过程,而支配性量词却只尝试一次,不合口味就算了。就像一个出身高贵居支配地位的公主。但你也可以说它是最懒量词。由于javascript不支持,所以它连出场的机会也没有了。
// var re3 = /.*+bbb/g;//支配性,javascript不支持,IE与所有最新的标准浏览器都报错
|
alert(re1.test( "abbbaabbbaaabbbb1234" )+ "" ); //true
|
alert(re1.exec( "abbbaabbbaaabbbb1234" )+ "" ); //null
|
alert( "abbbaabbbaaabbbb1234" .match(re1)+ "" ); //abbbaabbbaaabbbb
|
alert(re2.test( "abbbaabbbaaabbbb1234" )+ "" ); //true
|
alert(re2.exec( "abbbaabbbaaabbbb1234" )+ "" ); //aabbb
|
alert( "abbbaabbbaaabbbb1234" .match(re2)+ "" ); //abbb,aabbb,aaabbb
|
分组
到目前为止,我们只能一个字符到匹配,虽然量词的出现,能帮助我们处理一排密紧密相连的同类型字符。但这是不够的,下面该轮到小括号出场了,中括号表示范围内选择,大括号表示重复次数。小括号允许我们重复多个字符。
alert(/(dog){2}/.test( "dogdog" )) //true
|
alert( "baddad" .match(/([bd]ad?)*/)) //baddad,dad
|
alert( "mon and dad" .match(/(mon( and dad)?)/)) //mon and dad,mon and dad, and dad
|
反向引用
反向引用标识由正则表达式中的匹配组捕获的子字符串。每个反向引用都由一个编号或名称来标识,并通过“\编号”表示法进行引用。
alert(RegExp.$1); //990000
|
alert(/(dog)\1/.test( "dogdog" )) //true
|
var newNum = num.replace(/(\d{4}) (\d{4})/, "$2 $1" );
|
候选
继续在分组上做文章。在分组中插入管道符(“|”),把它划分为两个或多个候多项。
var reg = /(red|black|yellow)!!/;
|
alert(reg.test( "red!!" )) //true
|
alert(reg.test( "black!!" )) //true
|
alert(reg.test( "yellow!!" )) //true
|
非捕获性分组
并不是所有分组都能创建反向引用,有一种特别的分组称之为非捕获性分组,它是不会创建反向引用。反之,就是捕获性分组。要创建一个非捕获性分组,只要在分组的左括号的后面紧跟一个问号与冒号就行了。
题目,移除所有标签,只留下innerText!
var html = "<p><a href='http://www.cnblogs.com/rubylouvre/'>Ruby Louvre</a>by <em>司徒正美</em></p>" ;
|
var text = html.replace(/<(?:.|\s)*?>/g, "" );
|
注意:javascript不存在命名分组
前瞻
继续在分组内做文章。前瞻与后瞻其实都属于零宽断言,但javascript不支持后瞻。
零宽断言
|
正则
|
名称
|
描述
|
(?=exp)
|
正向前瞻
|
匹配exp前面的位置
|
(?!exp)
|
负向前瞻
|
匹配后面不是exp的位置
|
(?<=exp)
|
正向后瞻
|
匹配exp后面的位置不支持
|
(?<!exp)
|
负向后瞻
|
匹配前面不是exp的位置不支持
|
正向前瞻用来检查接下来的出现的是不是某个特定的字符集。而负向前瞻则是检查接下来的不应该出现的特定字符串集。零宽断言是不会被捕获的。
var reBed = /(bed(?=room)) ///在我们捕获bed这个字符串时,抢先去看接下来的字符串是不是room
|
alert(reBed.test(str1)); //true
|
alert(RegExp.$2 === "" ) //true
|
alert(reBed.test(str2)) //false
|
var reBed = /(bed(?!room))/ //要来它后面不能是room
|
alert(reBed.test(str1)) //false
|
alert(reBed.test(str2)) //true
|
题目,移除hr以外的所有标签,只留下innerText!
var html = "<p><a href='http://www.cnblogs.com/rubylouvre/'>Ruby Louvre</a></p><hr/><p>by <em>司徒正美</em></p>" ;
|
var text = html.replace(/<(?!hr)(?:.|\s)*?>/ig, "" )
|
alert(text) //Ruby Louvre<hr/>by 司徒正美
|
边界
一个要与字符类合用的东西。
边界
|
正则
|
名称
|
描述
|
^
|
开头
|
注意不能紧跟于左中括号的后面
|
$
|
结尾
|
|
\b
|
单词边界
|
指[a-zA-Z_0-9]之外的字符
|
\B
|
非单词边界
|
|
题目,设计一个字符串原型方法,实现首字母大写!
String.prototype.capitalize = function () {
|
return this .replace(/^\w/, function (s) {
|
alert(a.capitalize()) //Ruby
|
单词边界举例。要匹配的东西的前端或未端不能为英文字母阿拉伯字数字或下横线。
var str = "12w-eefd&efrew" ;
|
alert(str.match(/\b\w+\b/g)) //12w,eefd,efrew
|
实例属性
|
描述
|
global
|
是当前表达式模式首次匹配内容的开始位置,从0开始计数。其初始值为-1,每次成功匹配时,index属性都会随之改变。
|
ignoreCase
|
返回创建RegExp对象实例时指定的ignoreCase标志(i)的状态。如果创建RegExp对象实例时设置了i标志,该属性返回True,否则返回False,默认值为False。
|
lastIndex
|
是当前表达式模式首次匹配内容中最后一个字符的下一个位置,从0开始计数,常被作为继续搜索时的起始位置,初始值为-1, 表示从起始位置开始搜索,每次成功匹配时,lastIndex属性值都会随之改变。(只有使用exec()或test()方法才会填入,否则为0)
|
multiLine
|
返回创建RegExp对象实例时指定的multiLine标志(m)的状态。如果创建RegExp对象实例时设置了m标志,该属性返回True,否则返回False,默认值为False。
|
source
|
返回创建RegExp对象实例时指定的表达式文本字符串。
|
alert(reg.lastIndex);
//6
JAVASCRIPT 正则表达式学习--基础与零宽断言(转自司徒正美)相关推荐
- 正则表达式零宽断言详解
在使用正则表达式时,有时我们需要捕获的内容前后必须是特定内容,但又不捕获这些特定内容的时候,零宽断言就起到作用了. 一.基本概念: 零宽断言正如它的名字一样,是一种零宽度的匹配,它匹配到的内容不会保存 ...
- javascript 正则表达式-零宽断言
http://buzheng.org/blog/regex-zero-width-assertion/ 正则表达式里面比较高级的应用就属于零宽断言了.那么什么是零宽断言呢?拆分法从字面上分析一下,零宽 ...
- php 零宽断言,正则表达式之零宽断言实例详解【基于PHP】
这篇文章主要介绍了正则表达式之零宽断言,简单介绍了零宽断言的概念.分类及php实现技巧与相关注意事项,需要的朋友可以参考下 本文实例讲述了正则表达式之零宽断言.分享给大家供大家参考,具体如下: 前言 ...
- php 正则 零宽断言,正则表达式之零宽断言实例详解_正则表达式
这篇文章主要介绍了正则表达式之零宽断言,简单介绍了零宽断言的概念.分类及php实现技巧与相关注意事项,需要的朋友可以参考下 本文实例讲述了正则表达式之零宽断言.分享给大家供大家参考,具体如下: 前言 ...
- grep零宽断言正则表达式
一.grep零宽断言: (匹配宽度为零,满足一定的条件/断言) 零宽断言用于查找在某些内容(但并不包括这些内容)之前或之后的东西,也就是说它们像 \b ^ $ \< \> 这样的锚定作用, ...
- Python正则表达式之零宽断言(4)
文章目录 声明 | ^ $ \A \Z \b \B 分组 反向引用 注意 声明 有些元字符它们不匹配任何字符,只是简单地表示成功或失败,因此这些字符也称之为零宽断言.例如 \b 表示当前位置位于一个单 ...
- 正则表达式之零宽断言
介绍: 零宽断言用于查找在某些内容(但并不包括这些内容)之前或之后的东西,也就是说它们像 \b ^ $ \< \> 这样的锚定作用,用于指定一个位置,这个位置应该满足一定的条件(即断言), ...
- php 零宽断言,正则表达式之零宽断言实例详解
这篇文章主要介绍了正则表达式之零宽断言,简单介绍了零宽断言的概念.分类及php实现技巧与相关注意事项,需要的朋友可以参考下 本文实例讲述了正则表达式之零宽断言.分享给大家供大家参考,具体如下: 前言 ...
- 【正则表达式系列】零宽断言
一:基本概念 零宽断言正如它的名字一样,是一种零宽度的匹配,它匹配到的内容不会保存到匹配结果中去,最终匹配结果只是一个位置而已. 二:用法 1:(?=exp):零宽度正预测先行断言,它断言自身出现的位 ...
最新文章
- 【Java源码分析】ArrayList源码分析
- Jenkins 部署
- 有艺术细胞,就一定能做个好的游戏美术吗?
- 机器学习中的相似性度量总结
- 年龄是计数还是计量_MSA你只知道计量型和计数型?有哪些类型?分别是什么方法?...
- python飞机大战概要设计说明书_飞机大战概要设计文档 4改
- 信息管理与信息系统专业渊源
- Javaweb —— JSP技术
- 金融业大数据应用场景
- html 左侧固定导航栏,前端布局-固定导航栏与侧边栏
- 【95】太空射击游戏——玩家代码
- ​杭州阿里、海康、网易等组成 HR 联盟,以后你还敢跳槽吗?
- Email-FTP-RTSP协议实践研究
- 圣剑传说 玛娜传奇(Legend of Mana)(LOM)全武器取得方法
- 焦作机器人编程比赛_2018 焦作icpc现场赛总结
- 高通滤波与低通滤波的简单理解
- Delphi隐藏/显示Windows桌面上的图标
- Atcoder 284题解
- Moho Pro - Mac 上一款专业的二维动画制作软件,强大的功能让你尽情发挥创意
- Shannon极限与Nyquist极限
热门文章
- 数字孪生世界白皮书(2022) 附下载
- DOE中的“已编码系数”和“以未编码单位表示的回归方程”
- Python 学习Task07!
- 02.07Center Alignment居中对齐
- 白话详解ROCAUC | 小白深度学习入门
- Jim Williams神作:The Art and Science of Analog Circuit Design.pdf文件免费分享
- 全球与中国成人智能尿布市场产销需求与发展方向分析报告2022-2028年版
- deviance resolve达芬奇15 mac 破解教程
- 一个c加一个g是什么牌子_皮带有个g是什么牌子?皮带上有g是哪个品牌?
- 小新700显卡驱动下载地址