.*? 和 .*的区别

在看js代码的时候,有时候会遇到 .*? 这样的写法,那么连续两个限制符是什么意思呢?咱们先来回顾一下正则表达式的基本知识。web

基本语法

符号 用法
. 匹配除“\r\n”以外的任何单个字符。要匹配包括“\r\n”在内的任何字符,请使用像“[\s\S]”的模式。
? 匹配前面的子表达式0到1次
* 匹配前面的子表达式人任意次
+ 匹配前面的子表达式一次或屡次(大于等于1次)

懒惰匹配

表达式 .* 的意思很好理解,就是单个字符匹配任意次,即贪婪匹配。
表达式 .*? 是知足条件的状况只匹配一次,即懒惰匹配正则表达式

这是什么 意思?咱们用例子来解释。svg

var str = 'Anna is {age} years old,Bob is {age} years old too';
var expr = /{.*?}/g;
console.log(str.replace(expr, '13'));

命令行输出: Anna is 13 years old,Bob is 13 years old tooui

能够看出,懒惰模式下,只要知足条件,就再也不向后匹配,如下是贪婪模式:spa

var str = 'Anna is {age} years old,Bob is {age} years old too';
var expr = /{.*}/g;
console.log(str.replace(expr, '13'));

命令行输出: Anna is 13 years old too命令行

中间全部知足条件的都被替换了code

注意

像 .+* 以及 .*+这种表达式是错误的,命令行会报错。若是但愿贪婪匹配,直接 .* 或者 .+就能够regexp