js关键字标红

TP:以下两种方法多次匹配也不会造成匹配结果混乱的问题

  1. 第一种方法
javascript 复制代码
let keyword = ["red", "color", ">"];
let tableData = {
  MatchCompanyName: "color fjkfffs red >",
};

// 关键词高亮函数
function highlightKeywords(data, keywords) {
  let matchCompanyName = data.MatchCompanyName;
  let result = '';
  let lastIndex = 0;

  // 构建一个正则表达式,将所有关键词合并到一个表达式中
  const regex = new RegExp(keywords.join('|'), 'gi');

  // 遍历所有的匹配项
  matchCompanyName.replace(regex, (match, index) => {
    // 拼接匹配前的部分
    result += matchCompanyName.slice(lastIndex, index);
    // 拼接高亮的部分
    result += `<span class="highlighted">${match}</span>`;
    // 更新最后一个匹配结束的索引
    lastIndex = index + match.length;
  });

  // 拼接剩余的部分
  result += matchCompanyName.slice(lastIndex);

  return result;
}

// 获取高亮后的结果
let highlightedText = highlightKeywords(tableData, keyword);

// 输出结果或更新 DOM
console.log(highlightedText);

// 在 HTML 中可以使用 "highlighted" 类进行样式设置
/*
<style>
  .highlighted {
    color: red;
  }
</style>
*/
  1. 第二种
javascript 复制代码
let keyword = ["red", "color", ">"];
let tableData = {
  MatchCompanyName: "color fjkfffs red >",
};

// 函数用于根据关键词高亮匹配项
function highlightKeywords(data, keywords) {
  let matchCompanyName = data.MatchCompanyName;
  let highlights = []; // 用于存储匹配的起始和结束位置

  // 查找每个关键词的匹配位置
  keywords.forEach((word) => {
    const regex = new RegExp(word, 'gi'); // 大小写不敏感匹配
    let match;
    while ((match = regex.exec(matchCompanyName)) !== null) {
      highlights.push({ start: match.index, end: regex.lastIndex });
    }
  });

  // 按照匹配的位置从后往前插入 <span>,避免位置错乱
  highlights.sort((a, b) => b.start - a.start);

  highlights.forEach((highlight) => {
    matchCompanyName =
      matchCompanyName.slice(0, highlight.start) +
      '<span class="highlighted">' +
      matchCompanyName.slice(highlight.start, highlight.end) +
      '</span>' +
      matchCompanyName.slice(highlight.end);
  });

  return matchCompanyName;
}

// 获取高亮后的结果
let highlightedText = highlightKeywords(tableData, keyword);

// 输出结果或更新 DOM
console.log(highlightedText);

// 在 HTML 中可以使用 "highlighted" 类进行样式设置
/*
<style>
  .highlighted {
    color: red;
  }
</style>
*/

总结:第一种方法通过一次遍历来找到所有的匹配项并构建新的字符串,避免在替换时频繁地操作字符串。这种方式减少了字符串的拼接操作,提高了性能。

相关推荐
酷爱码16 分钟前
Linux实现临时RAM登录的方法汇总
linux·前端·javascript
LuckyLay19 分钟前
Vue百日学习计划Day16-18天详细计划-Gemini版
前端·vue.js·学习
想要飞翔的pig36 分钟前
uniapp+vue3页面滚动加载数据
前端·vue.js·uni-app
HarryHY36 分钟前
git提交库常用词
前端
SoraLuna36 分钟前
「Mac畅玩AIGC与多模态41」开发篇36 - 用 ArkTS 构建聚合搜索前端页面
前端·macos·aigc
Wannaer38 分钟前
从 Vue3 回望 Vue2:性能优化内建化——从黑盒优化到可控编译
javascript·vue.js·性能优化
霸王蟹43 分钟前
React Fiber 架构深度解析:时间切片与性能优化的核心引擎
前端·笔记·react.js·性能优化·架构·前端框架
benben04443 分钟前
Unity3D仿星露谷物语开发44之收集农作物
前端·游戏·unity·游戏引擎
会功夫的李白1 小时前
uniapp自动构建pages.json的vite插件
前端·uni-app·vite
一口一个橘子1 小时前
[ctfshow web入门] web77
前端·web安全·网络安全