发布网友 发布时间:2022-04-22 08:27
共5个回答
热心网友 时间:2022-04-22 19:47
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"]。
扩展资料:
常用的正则字符
1、\ : 将下一个字符标记为一个特殊字符、或一个原义字符、或一个 向后引用、或一个八进制转义符。
2、^:匹配输入字符串的开始位置。如果设置了 RegExp 对象的 Multiline 属性,^ 也匹配 'n' 或 'r' 之后的位置。
3、$:匹配输入字符串的结束位置。如果设置了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}) 后面时,匹配模式是非贪婪的。
非贪婪模式尽可能少的匹配所搜索的字符串,而默认的贪婪模式则尽可能多的匹配所搜索的字符串。
热心网友 时间:2022-04-22 21:05
个人觉得可以定位<123> 後面的>位置,然後在定位<456> 前面的<的位置,截取中间的字符串热心网友 时间:2022-04-22 22:39
var str="我是中国人啊哈哈为什么呢";var newStr=str.substring(2, 11);热心网友 时间:2022-04-23 00:31
var str = "这是一段话_很好的一段话!";热心网友 时间:2022-04-23 02:39
var newStr = str.subString(5, str.length - 5);追问额。。数字的长度也是不固定的 该怎么办