正则表达式
Posted lvsk
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了正则表达式相关的知识,希望对你有一定的参考价值。
表达式
/^[0-9]+abc$/ // 以数字开始 abc字符串结束 123abc
// + 表示前面的字符必须至少出现一次
var patt=/^[0-9]+abc$/;
var result=patt.test(‘abc‘); // false
/^[0-9]*abc$/ // 以数字开始 abc字符串结束 abc
// * 表示前面的字符可以不出现,也可以出现一次或者多次
var patt=/^[0-9]*abc$/;
var result=patt.test(‘abc‘); //true
/^[0-9]?abc$/ // 以数字开始 abc字符串结束 abc
// ? 表示前面的字符最多只可以出现一次
var patt=/^[0-9]?abc$/;
var result=patt.test(‘abc‘); //true
var result=patt.test(‘1abc‘); //true
var result=patt.test(‘12abc‘); //false
/^[a-z0-9_-]{3,5}$/ // 只允许用包含字符、数字、下划线和连接字符(-),并设置长度
// s 空格符
// /s*$/ 右侧空格
// /^s*/ 左侧空格
// /s/g 全部空格
若要匹配特殊字符,需要在特殊字符前面加 / , 如 * , /* 表示匹配 * 字符
* | 匹配前面的子表达式零次或多次。例如,zo* 能匹配 "z" 以及 "zoo"。* 等价于{0,}。 |
+ | 匹配前面的子表达式一次或多次。例如,‘zo+‘ 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等价于 {1,}。 |
? | 匹配前面的子表达式零次或一次。例如,"do(es)?" 可以匹配 "do" 、 "does" 中的 "does" 、 "doxy" 中的 "do" 。? 等价于 {0,1}。 |
{n} | n 是一个非负整数。匹配确定的 n 次。例如,‘o{2}‘ 不能匹配 "Bob" 中的 ‘o‘,但是能匹配 "food" 中的两个 o。 |
{n,} | n 是一个非负整数。至少匹配n 次。例如,‘o{2,}‘ 不能匹配 "Bob" 中的 ‘o‘,但能匹配 "foooood" 中的所有 o。‘o{1,}‘ 等价于 ‘o+‘。‘o{0,}‘ 则等价于 ‘o*‘。 |
{n,m} | m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。例如,"o{1,3}" 将匹配 "fooooood" 中的前三个 o。‘o{0,1}‘ 等价于 ‘o?‘。请注意在逗号和两个数之间不能有空格。 |
以上是关于正则表达式的主要内容,如果未能解决你的问题,请参考以下文章
正则表达式匹配特定的 URL 片段而不是所有其他 URL 可能性