| 代码 | 说明 |
| — | — |
| \f | 匹配一个换页符 |
| \n | 匹配一个换行符 |
| \r | 匹配一个回车符 |
| \t | 匹配一个水平制表符 |
| \v | 匹配一个垂直制表符 |
| * | 匹配* |
| . | 匹配. |
| \ | 匹配\ |
| 代码 | 说明 |
| — | — |
| x | y | 匹配x或y |
| [xyz] | 字符集合。匹配所包含的任意一个字符。例如’[abc]’ 可以匹配 “plain” 中的 ‘a’。 |
| [^xyz] | 负值字符集合。匹配未包含的任意字符。例如’[^abc]’ 可以匹配 “plain” 中的’p’、‘l’、‘i’、‘n’。 |
| [a-z] | 字符范围。匹配指定范围内的任意字符 |
| [^a-z] | 负值字符范围。匹配任何不在指定范围内的任意字符。 |
回到顶部 目录
| 分类 | 代码 | 说明 |
| — | — | — |
| 捕获 | (exp) | 匹配exp,并捕获文本到自动命名的组里面 |
| | (?exp) | 匹配exp,并捕获文本到名称为name的组里 |
| | (?:exp) | 匹配exp,不捕获匹配的文本,也不给此分组分配编号 |
| 零度断言 | (?=exp) | 匹配exp前面的位置 |
| | (?<=exp) | 匹配exp后面的位置 |
| | (?!exp) | 匹配后面跟着不是exp的位置 |
| | (?<!exp) | 匹配强面不是exp的位置 |
| 注释 | (?#comment) | 这种类型的分组不对正则表达式的处理产生任何影响,只是提供注释让人阅读 |
每使用一对()小括号,就是分了一个小组,并且每个小组都有一个编号
系统自动分配编号的原则是:
-
从左到右分配编号,第一个组是1,第二个是2,以此类推(正则表达式整体是一个组,编号为0)
-
实现上会从右到左查询两次,第一次给未命名的组分配组号,第二次给已命名的组分配组号
-
可以使用(?:xxx)的语法来让一个组不参与自动分配组号
后向引用
后向引用是指通过反斜杠\
加上 数字(编号)的方式来重复使用某一组的正则表达式
例如:(\d+)\s{1}\1
这个式子中可看出\d+
是第1组,编号就是1,后面的\1
就是引用了前面这一组的内容,相当于 (\d+)\s{1}(\d+)
零度断言
匹配宽度为0,在匹配元素的位置设置断点
比如一个字符串ddexpaa
dd(?=exp):匹配exp前面的dd
(?=exp)aa:匹配exp后面的aa
比如一个字符串aabab
贪婪的正则匹配:a.*b ==> 匹配到aabab一个结果
懒惰的正则匹配:a.*?b ==> 匹配到aab和ab两个结果
贪婪的重复
| 代码 | 说明 |
| — | — |
| * | 重复0次或者无数次 |
| + | 重复1次或者无数次 |
| ? | 重复0次或者1次 |
| {n} | 重复n次 |
| {n,} | 重复n次或者重复n次以上 |
| {n, m} | 重复n到m次 |
懒惰的重复
| 代码 | 说明 |
| — | — |
| *? | 重复任意次,但尽可能少重复 |
| +? | 重复1次或者更多次,但尽可能少重复 |
| ?? | 重复0次或者1次,但尽可能少重复 |
| {n,m}? | 重复n到m次,但尽可能少重复 |
| {n,}? | 重复n次以上,但尽可能少重复 |
JavaScript
-
js的基本类型有哪些?引用类型有哪些?null和undefined的区别。
-
如何判断一个变量是Array类型?如何判断一个变量是Number类型?(都不止一种)
-
Object是引用类型嘛?引用类型和基本类型有什么区别?哪个是存在堆哪一个是存在栈上面的?
-
JS常见的dom操作api
-
解释一下事件冒泡和事件捕获
-
事件委托(手写例子),事件冒泡和捕获,如何阻止冒泡?如何组织默认事件?
-
对闭包的理解?什么时候构成闭包?闭包的实现方法?闭包的优缺点?
-
this有哪些使用场景?跟C,Java中的this有什么区别?如何改变this的值?
-
call,apply,bind
-
显示原型和隐式原型,手绘原型链,原型链是什么?为什么要有原型链
-
创建对象的多种方式
-
实现继承的多种方式和优缺点
-
new 一个对象具体做了什么
-
手写Ajax,XMLHttpRequest
-
变量提升
-
举例说明一个匿名函数的典型用例
-
指出JS的宿主对象和原生对象的区别,为什么扩展JS内置对象不是好的做法?有哪些内置对象和内置函数?
-
attribute和property的区别
-
document load和document DOMContentLoaded两个事件的区别
-
JS代码调试