react经验7:高亮关键字

预期效果:

实现原理

将需要高亮的关键词做成正则表达式

js 复制代码
new RegExp(`(${word})`, "gi")

使用上述正则表达式切割目标字符串

js 复制代码
origin.split(new RegExp(`(${word})`, "gi"))

切割结果会包含正则匹配到的词

过滤掉空字符,并对关键词包裹一层标签,以设置其样式

ts 复制代码
/**处理高亮词
*@param origin 目标字符串
*@param word 关键词
*@returns {ReactNode[]}
*/
function highlightWord(origin: string, word: string) {
    if (!word) {
        return [origin]
    }
    const sps = origin.split(new RegExp(`(${word})`, "gi"))
    //排除空字符,并对关键词包裹标签
    return sps.filter(c => c).map(c => {
        if (c.toLowerCase() === word.toLowerCase()) {
            return <mark>{c}</mark>
        }
        return c
    })
}

最后将切割处理后的结果渲染输出

js 复制代码
let title=highlightWord('12345','12')
js 复制代码
<label>
	{title.map(d=>d)}
</label>

上述代码实际会生成这个

html 复制代码
<label><mark>12</mark>345</label>

关键词被包裹了标签,此时就可以任意设定高亮样式了

相关推荐
用户9545156811622 分钟前
实际开发中 | 与 || 的使用方法及组件封装方案解析
前端
得帆云低代码4 分钟前
COC Asia 2025|得帆云 ETL:顺应 Hive 新特性,重塑数据管道的未来
前端
十字路口的火丁32 分钟前
前端开发如何灵活使用 css 变量
前端
_志哥_39 分钟前
深度解析:解决 backdrop-filter 与 border-radius 的圆角漏光问题
前端·javascript·html
南囝coding44 分钟前
100% 用 AI 做完一个新项目,从 Plan 到 Finished 我学到了这些
前端·后端
qiao若huan喜1 小时前
10、webgl 基本概念 + 坐标系统 + 立方体
前端·javascript·信息可视化·webgl
前端一课1 小时前
Vue3 的 Composition API 和 Options API 有哪些区别?举例说明 Composition API 的优势。
前端
用户47949283569151 小时前
都说node.js是事件驱动的,什么是事件驱动?
前端·node.js
晴殇i1 小时前
前端架构中的中间层设计:构建稳健可维护的组件体系
前端·面试·代码规范
申阳2 小时前
Day 7:05. 基于Nuxt开发博客项目-首页开发
前端·后端·程序员