首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Fuse.js includeMatches高亮显示-它是如何工作的?

Fuse.js includeMatches高亮显示-它是如何工作的?
EN

Stack Overflow用户
提问于 2021-05-02 10:08:05
回答 1查看 157关注 0票数 0

我将在我的下一个JS/Typescript web应用程序中使用Fuse.js库。我不确定includeMatches选项是如何用于突出显示的。如果我使用该选项,我将在result对象中获得一个matches对象,该对象包含一大堆from和to索引,而且它似乎比实际匹配的要多得多。

如何使用此数组进行高亮显示?有没有人?

EN

回答 1

Stack Overflow用户

发布于 2021-09-15 08:07:17

https://gist.github.com/evenfrost/1ba123656ded32fb7a0cd4651efd4db0是一个很好的起点。

代码语言:javascript
复制
const highlight = (fuseSearchResult: any, highlightClassName: string = 'highlight') => {
  const set = (obj: object, path: string, value: any) => {
      const pathValue = path.split('.');
      let i;

      for (i = 0; i < pathValue.length - 1; i++) {
        obj = obj[pathValue[i]];
      }

      obj[pathValue[i]] = value;
  };

  const generateHighlightedText = (inputText: string, regions: number[] = []) => {
    let content = '';
    let nextUnhighlightedRegionStartingIndex = 0;

    regions.forEach(region => {
      const lastRegionNextIndex = region[1] + 1;

      content += [
        inputText.substring(nextUnhighlightedRegionStartingIndex, region[0]),
        `<span class="${highlightClassName}">`,
        inputText.substring(region[0], lastRegionNextIndex),
        '</span>',
      ].join('');

      nextUnhighlightedRegionStartingIndex = lastRegionNextIndex;
    });

    content += inputText.substring(nextUnhighlightedRegionStartingIndex);

    return content;
  };

  return fuseSearchResult
    .filter(({ matches }: any) => matches && matches.length)
    .map(({ item, matches }: any) => {
      const highlightedItem = { ...item };

      matches.forEach((match: any) => {
        set(highlightedItem, match.key, generateHighlightedText(match.value, match.indices));
      });

      return highlightedItem;
    });
};

// usage:

const res = highlight(fuse.search(text)); // array of items with highlighted fields
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67352406

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档