正则表达式 (Regular Expression)

定义:用来对字符串里的信息实现查找.替换和提取操作。

字符串

查找

charAt(n) //从0开始的第n个  
search("")//结果为>-1则有该字符串,为-1时则没有  
split("-")//"2017-8=24" 结果为["2017","8","24"]  
slice(1)//"#a=1&b=2"结果为"a=1&b=2"    

截取.提取

substr(n,m)//n表示从n开始,m表示截取m位  
substring(n,m)//n表示从n开始,m表示截取到m位(不包含m)  

替换

replace("is","Is")//将"is"替换成"Is",只能替换1次,想替换n次,则写n次。 由于这个方法比较麻烦,所以我们学习正则表达式。 

正则表达式

|| 自变量  
new RegExp()   

修饰符

i   ignore 忽略大小写  
g   global 全局 全部  
m   multiline   多行 

字符

普通字符

a-z  A-Z  0-9   

特殊字符

$  匹配输入字符串的结尾位置。如果设置了 RegExp 对象的 Multiline 属性,则 $ 也匹配 '\n' 或 '\r'。要匹配 $ 字符本身,请使用 \$。    
()  标记一个子表达式的开始和结束位置。子表达式可以获取供以后使用。要匹配这些字符,请使用 \( 和 \)。  
*  匹配前面的子表达式零次或多次。要匹配 * 字符,请使用 \*。  
+  匹配前面的子表达式一次或多次。要匹配 + 字符,请使用 \+。  
.  匹配除换行符 \n 之外的任何单字符。要匹配 . ,请使用 \. 。  
[]  标记一个中括号表达式的开始。要匹配 [,请使用 \[。  
?  匹配前面的子表达式零次或一次,或指明一个非贪婪限定符。要匹配 ? 字符,请使用 \?。  
\  将下一个字符标记为或特殊字符、或原义字符、或向后引用、或八进制转义符。例如, 'n' 匹配字符 'n'。'\n' 匹配换行符。序列 '\\' 匹配 "\",而 '\(' 则匹配 "("。  
^  匹配输入字符串的开始位置,除非在方括号表达式中使用,此时它表示不接受该字符集合。要匹配 ^ 字符本身,请使用 \^。  
{}  标记限定符表达式的开始。要匹配 {,请使用 \{。  
|  指明两项之间的一个选择。要匹配 |,请使用 \|。

预定义字符

\n 匹配一个换行符  
\r 匹配一个回车符  
\f 匹配一个换页符  
\s 匹配任何空白字符,包括空格、制表符、换页符等等  
\S 匹配任何非空白字符  
\t 匹配一个制表符  
\v 匹配一个垂直制表符  
\b 匹配一个单词的边界   
\B 匹配一个单词的非边界   
\d 匹配一个字数字符,/\d/ = /[0-9]/   
\D 匹配一个非字数字符,/\D/ = /[^0-9]/   
[\b] 匹配一个退格符 

哈希
744 声望8 粉丝