JS截取指定字符串到指定字符串之间的内容

JS截取指定字符串到指定字符串之间的内容

var str="<123>asdadsadsa<456>";
str = str.match(/<123>(\S*)<456>/)[1];
console.log(str);

\S:匹配任何非空白字符。

*:匹配前面的子表达式零次或多次。

match方法:

//语法
stringObject.match(searchvalue)

stringObject.match(regexp)

searchvalue:必需。规定要检索的字符串值。

regexp:必需。规定要匹配的模式的 RegExp 对象。如果该参数不是 RegExp 对象,则需要首先把它传递给 RegExp 构造函数,将其转换为 RegExp 对象。

如果 regexp 没有标志 g,那么 match() 方法就只能在 stringObject 中执行一次匹配。如果没有找到任何匹配的文本, match() 将返回 null。否则,它将返回一个数组。例如:

"186a619b28".match(/\d+/g); 

如果上面的匹配不是全局匹配,那么得到的结果如下:

[“186”, index: 0, input: “186a619b28”]。

JS截取指定字符串到指定字符串之间的内容

扩展资料:

常用的正则字符

1、\ : 将下一个字符标记为一个特殊字符、或一个原义字符、或一个向后引用、或一个八进制转义符。

2、^:匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 ‘n’ 或 ‘r’ 之后的位置。

3、 : 匹 配 输 入 字 符 串 的 结 束 位 置 。 如 果 设 置 了 R e g E x p 对 象 的 M u l t i l i n e 属 性 , :匹配输入字符串的结束位置。如果设置了RegExp 对象的 Multiline 属性, :匹配输入字符串的结束位置。如果设置了RegExp对象的Multiline属性, 也匹配 ‘n’ 或 ‘r’ 之前的位置。

4、+:匹配前面的子表达式一次或多次。

5、?:匹配前面的子表达式零次或一次。

6、{n}:n 是一个非负整数。匹配确定的 n 次。

7、{n,}:n 是一个非负整数。至少匹配n 次。

8、{n,m}:m 和 n 均为非负整数,其中n <= m。最少匹配 n 次且最多匹配 m 次。请注意在逗号和两个数之间不能有空格。

9、?:当该字符紧跟在任何一个其他限制符 (*, +, ?, {n}, {n,}, {n,m}) 后面时,匹配模式是非贪婪的。

非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。

上一篇:powershell 正则表达式 -match


下一篇:《设计模式(五)之——抽象工厂模式》