javascript - 为什么这个 javascript 非贪婪正则表达式没有匹配任何内容?

标签 javascript regex regex-greedy non-greedy

有了下面的 url 和 js 正则表达式,我希望捕获 f2fJsDFJ23,但非贪婪部分 .*?\?? 未按预期工作

理由是什么?

let t = 'https://www.youtube.com/embed/f2fJsDFJ23?autoplay=1'
let reg = /(?:embed\/)(.*?)(?:\??)/.exec(t)
document.write(`6>>> ${reg && reg.join(' | ')} <br/>`)

reg = /(?:embed\/)(.*)(?:\??)/.exec(t)
document.write(`6>>> ${reg && reg.join(' | ')} <br/>`)

reg = /(?:embed\/)(.*)(?:\?)/.exec(t)
document.write(`6>>> ${reg && reg.join(' | ')} <br/>`)

t = 'https://www.youtube.com/embed/f2fJsDFJ23'
reg = /(?:embed\/)(.*?)(?:\??)/.exec(t)
document.write(`6>>> ${reg && reg.join(' | ')} <br/>`)

reg = /(?:embed\/)(.*)(?:\??)/.exec(t)
document.write(`6>>> ${reg && reg.join(' | ')} <br/>`)

reg = /(?:embed\/)(.*)(?:\?)/.exec(t)
document.write(`6>>> ${reg && reg.join(' | ')} <br/>`)

最佳答案

在您的模式中,(.*?) 部分是非贪婪的,放弃尽可能少。之后它将匹配一个可选的问号。由于问号是可选的,因此点非贪婪,因此该模式足以匹配 embed/only。

一种选择是匹配 ? 或使用 alternation 断言字符串 $ 的结尾.

请注意,您可以省略嵌入周围的非捕获组和问号。

embed\/(.*?)(?:\?|$)

Regex demo

<小时/>

另一种选择是使用否定字符类来匹配除 ? 或空白字符之外的任何字符:

embed\/([^?\s]*)

Regex demo

关于javascript - 为什么这个 javascript 非贪婪正则表达式没有匹配任何内容?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58890599/

相关文章:

javascript - 在我的情况下如何使用 ng-click 功能?

javascript - 在javascript中将数组添加到特定位置(基于键值)的数组中

javascript - 在触摸设备的 HTML5 中使用 touchmove 在 Canvas 内拖动或移动图像

正则表达式匹配广告而不是下载

JavaScript 正则表达式 : Match additionals based on path delimiter

javascript - 尝试在 Firefox 中使用 iframe 进行渲染时,如何隐藏 pdf 文件附带的工具栏?

Java:匹配城市正则表达式

Python - 将 url 拆分为其组件

python - 正则表达式:匹配括号贪婪和非贪婪

Java模式匹配最大可能的组