dm_xx 2022-09-25 21:57 采纳率: 75%
浏览 32
已结题

js怎么避免替换标签内容

问题遇到的现象和发生背景
let str1 = ["c","v","r"];
let str2 = "cvr";
for (let i = 0; i < str1.length; i++) {
       let reg = new RegExp(`${str1[i]}`,'g');
       str2 =  str2.replace(reg, match => `<span style = 'background-color:#f3c061;'>${match}</span>`);
}
console.log(str2);

这种方法怎么避免标签内容也被替换?

运行结果及报错内容

<span style = 'background-color:#f3c061;'>c<span style = 'background-color:#f3c061;'>vr

img

这是替换的最后结果,把标签内容也替换了。

我想要达到的结果

循环替换的时候可以不替换标签里面的内容

  • 写回答

1条回答 默认 最新

  • MAXLZ 2022-09-25 22:35
    关注
    let str1 = ["c","v","r"];
    let str2 = "cvr";
    const reg = new RegExp(`(${str1.join('|')})`, 'g')
    const res = str2.replace(reg, match => `<span style = 'background-color:#f3c061;'>${match}</span>`)
    console.log(res)
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月3日
  • 已采纳回答 9月25日
  • 修改了问题 9月25日
  • 创建了问题 9月25日

悬赏问题

  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应