【uniapp】vue2 搜索文字高亮显示

【uniapp】vue2 搜索文字高亮显示

我这里是把方法放在公共组件中使用

javascript 复制代码
props: {
    // 帖子list
    postList: {
		type: Array,
		required: true
    },
    // 搜索文本字体高亮
    highLightSearch: {
		type: String,
		required: false
    }
},
watch: {
    // 监听 props 的变化
     postList: {
       immediate: true,
         handler(newVal) {
					// 变化后的新值, 当前的高亮搜索词
            this.updateHighlightedPostList(newVal, this.highLightSearch);
         },
      },
},
methods: {
   updateHighlightedPostList(postList, searchKeyword) {
       // 检查是否有搜索关键字
	   if (!searchKeyword) {
		this.highlightedPostList = [...postList]
		return
       }
       // 创建正则表达式匹配关键字(g 全局匹配,i 不区分大小写)
       const regex = new RegExp(`(${searchKeyword})`, "gi");
       // 更新高亮内容
       this.highlightedPostList = postList.map((item) => ({
          ...item,
          title: item.title.replace(
             regex,
             `<text class="hight_blue">$1</text>` // 将匹配到的内容 ($1) 包裹在 <text> 标签中
          ),
       }));
   },
}
html 复制代码
<view v-for="p in highlightedPostList" :key="p.id">
    <!-- 页面文字展示一定要用 v-html 便于解析标签样式 -->
    <view v-html="p.title" class=""></view>
</view>

高亮实现方式是用 HTML 标签包裹匹配文本,通过 CSS 控制样式

注意事项:

使用 v-html 显示 title 时要小心 XSS 攻击,确保 searchKeyword 是可信的

如果 postList 很大,频繁更新可能影响性能,可以考虑防抖

正则表达式中的特殊字符可能需要转义

相关推荐
二哈赛车手8 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
代码搬运媛8 小时前
Jest 测试框架详解与实现指南
前端
栗子~~8 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
YDS8299 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
counterxing9 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq9 小时前
windows下nginx的安装
linux·服务器·前端
之歆9 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
发现一只大呆瓜9 小时前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Maimai108089 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
未若君雅裁10 小时前
MyBatis 一级缓存、二级缓存与清理机制
java·缓存·mybatis