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>

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

相关推荐
Yan.love9 分钟前
【CSS-布局】终极方案:Flexbox 与 Grid 的“降维打击”
前端·css
曲幽28 分钟前
JavaScript流程控制:从混乱条件到优雅遍历,一次讲清如何让代码听话
javascript·web·js·for·while·if·if else
2501_9445264236 分钟前
Flutter for OpenHarmony 万能游戏库App实战 - 笑话生成器实现
android·javascript·python·flutter·游戏
请叫我聪明鸭40 分钟前
基于 marked.js 的扩展机制,创建一个自定义的块级容器扩展,让内容渲染为<div>标签而非默认的<p>标签
开发语言·前端·javascript·vue.js·ecmascript·marked·marked.js插件
悟能不能悟41 分钟前
Gson bean getxxx,怎么才能返回给前端
java·前端
2501_9447114343 分钟前
前端向架构突围系列 - 工程化(五):企业级脚手架的设计与落地
前端·架构
Apex Predator1 小时前
本地库导入到nexus
java·服务器·前端
趁着年轻吃点苦1 小时前
宝塔面板部署指南
前端
2501_944526421 小时前
Flutter for OpenHarmony 万能游戏库App实战 - 21点游戏实现
android·javascript·flutter·游戏·harmonyos
0思必得01 小时前
[Web自动化] Selenium中Select元素操作方法
前端·python·selenium·自动化·html