我正在尝试构建一个正则表达式,用一些 HTML 标记替换所有符号“$$”,例如 <someTag></someTag>
。
我使用这个正则表达式,但它并没有涵盖所有情况:
$$(\S[^\*]+\S)$$
'aaa $3$$ c$ ddd'.replace(/$$(\S[^\*]+\S)$$/g, '<a1></a1>') // works 'aaa $3$$ c$ $$ddd$$'.replace(/$$(\S[^\*]+\S)$$/g, '<a1></a1>') // doesn't work, should be 'aaa <a1>123</a1> c$ <a1>ddd</a1>'
console.log('aaa $3$$ c$ ddd'.replace(/$$(\S[^\*]+\S)$$/g, '<a1></a1>')) // works console.log('aaa $3$$ c$ $$ddd$$'.replace(/$$(\S[^\*]+\S)$$/g, '<a1></a1>')) // doesn't work, should be 'aaa <a1>123</a1> c$ <a1>ddd</a1>'
P粉7398862902024-04-02 13:41:43
不是正则表达式解决方案,但它有效。说明:使用分隔符 ($$
) 分割字符串。然后创建一个新字符串 result
并插入数组的每个部分。然后检查当前索引是奇数还是偶数,并根据情况添加开始标记 (prefix
) 或结束标记 (suffix
)。我希望这有帮助!
function replaceTag(string, delimiter, prefix, suffix){ let parts = string.split(delimiter); let result = ''; for(let index = 0; index < parts.length; index++){ result += parts[index]; if(index % 2 == 0 && index < parts.length - 1){ result += prefix; } else if(index < parts.length - 1){ result += suffix; } } return result; } console.log(replaceTag('aaa $3$$ c$ ddd', '$$', '', ' ')); console.log(replaceTag('aaa $3$$ c$ $$ddd$$', '$$', '', ' '));
P粉5920854232024-04-02 09:46:01
最快的方法是使用非贪婪的点全方法:/\$\$(.*?)\$\$/sg
https://regex101.com/r/upveAX/1
单独使用点总是会更快,因为它不依赖于断言或类结构,
这会增加 3 倍的性能开销。
console.log('aaa $3$$ c$ ddd'.replace(/$$(.*?)$$/sg, '')); console.log('aaa $3$$ c$ $$ddd$$'.replace(/$$(.*?)$$/sg, ' '));