< p >JavaScript 正則表達式中的平衡組是一種特殊的分組形式,它能夠匹配任意數量的嵌套字符串。平衡組在匹配嵌套字符串時非常有用,比如匹配 HTML 標簽內部的內容。通過平衡組,我們可以不再依賴于遞歸或棧來處理嵌套結構。< / p >< p >平衡組的核心思想是使用一對互相匹配的分隔符來標識嵌套的字符串。這對分隔符定義在正則表達式的開頭和結尾。之后,通過使用反向引用和零寬斷言,我們可以定義一個平衡組。下面是一個例子:< / p >< pre >const pattern = /start(?:(?!start|end)[\s\S])+?end/g;
const text = "start abc start def end end";
const matches = text.match(pattern);
console.log(matches); // ["start abc start def end", "start def end"]< / pre >< p >在這個例子中,我們想要匹配以 start 和 end 分隔的任意數量的字符串。我們使用了一個非獲取分組來匹配任意不包含 start 和 end 的字符。這個分組被重復執行,直到我們遇到了一個 end,這時整個分組被完整匹配。這個正則表達式的結果包含兩個匹配項:start abc start def end 和 start def end。< / p >< p >如果我們想要匹配一個嵌套的字符串,可以使用嵌套的分隔符。下面是一個匹配 HTML 標簽內部內容的例子:< / p >< pre >const pattern = /<([a-z]+)(?:[^<]+<(?!\/\1>)<\s*\/\1\s*>)+?<\/\1>/gi;
const text = "";
const matches = text.match(pattern);
console.log(matches); // ["", "
Exampletext
Exampletext
Exampletext
", "text"]< / pre >< p >這個正則表達式匹配包含 HTML 標簽的字符串中的內容。它首先匹配最外層標簽的開頭和結尾,然后使用嵌套的分隔符來匹配任意數量的標簽和非標簽字符。通過使用零寬斷言和反向引用,我們保證了標簽的開始和結尾是相匹配的。這個正則表達式的結果包含三個匹配項:整個字符串、p 標簽和 em 標簽。< / p >< p >JavaScript 正則表達式中的平衡組可以用來處理任意數量的嵌套字符串,比如 HTML 標簽內部的內容。通過使用一對互相匹配的分隔符來標識嵌套的字符串,并使用反向引用和零寬斷言來匹配嵌套字符串,我們可以輕松地處理嵌套結構,而無需依賴于遞歸或棧。< / p >上一篇java輸出素數和
下一篇css圖片橫著排代碼