Maison > Questions et réponses > le corps du texte
J'essaie de créer une expression régulière qui remplace tous les symboles "$$" par certaines balises HTML, telles que <someTag></someTag>
.
J'utilise cette regex, mais elle ne couvre pas tous les cas :
$$(\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
Ce n'est pas une solution regex, mais cela fonctionne. Description : Utilisez le délimiteur ($$
) 分割字符串。然后创建一个新字符串 result
并插入数组的每个部分。然后检查当前索引是奇数还是偶数,并根据情况添加开始标记 (prefix
) 或结束标记 (suffix
). J'espère que ça aide!
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
Le moyen le plus rapide est d'utiliser la méthode point à point non gourmande : /$$(.*?)$$/sg
https://regex101.com/r/upveAX/1
Utiliser dot seul sera toujours plus rapide car il ne repose pas sur des assertions ou des structures de classe,
Cela ajoute une surcharge de performances 3x.
console.log('aaa $3$$ c$ ddd'.replace(/$$(.*?)$$/sg, '')); console.log('aaa $3$$ c$ $$ddd$$'.replace(/$$(.*?)$$/sg, ' '));