搜索

首页  >  问答  >  正文

正则表达式用 HTML 标签替换几个符号

我正在尝试构建一个正则表达式,用一些 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粉362071992P粉362071992262 天前543

全部回复(2)我来回复

  • P粉739886290

    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$$', '$$', '', ''));

    回复
    0
  • P粉592085423

    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, ''));

    回复
    0
  • 取消回复