vue 实现实时搜索文档关键字并高亮显示

最近接到的一个新需求:实时搜索文档关键字并高亮显示,听起来好难的样子,仔细分析起来其实也蛮简单的。

实现思路

通过 input 实现关键字的输入,监听关键字的变化,用正则表达式来匹配关键字,然后给关键字添加样式实现高亮。

具体实现方法

这里我使用的是 vue2 + Element UI,其中 el-input 会自动监听输入值得变化。

html 复制代码
<div class="audio-search">
  <el-input
    placeholder="请输入内容"
    prefix-icon="el-icon-search"
    v-model="searchQuery"
    @input="inputSearch"
  >
  </el-input>
</div>
<!--这里是页面展示的文本-->
<div class="audio-text" v-html="newAudioText"></div>

js 部分

js 复制代码
data() {
	return {
		newAudioText: "测试文本测试",
		audioText: "测试文本测试",
		searchQuery: '', 
	}
},
methods: {
	 // 当关键字变化时,处理高亮逻辑
    inputSearch(){
      if(this.searchQuery){
        this.highlightText(this.audioText, this.searchQuery);
      } else {
        this.newAudioText = this.audioText
      }
    },
    // 实现搜索文字高亮的方法
    highlightText(text, query) {
      if (!query) {
        return text;
      }
	  // 正则是关键
      const escapedQuery = query.replace(/[.*+?^${}()|[\]\\]/g, '\\$&');
      const regex = new RegExp(escapedQuery, 'ig');

      this.newAudioText = text.replace(regex, match => `<span style="color: #d6000f;font-weight:bold">${match}</span>`);
    },
}

如此便实现了搜索关键字并高亮显示。

如果项目中有多处用到这个功能的,也可以用自定义指令封装一下高亮的方法,此处我略去了,有需要的自行实现吧。

相关推荐
前端开发呀1 分钟前
无所不能的uniapp拦截器【三】uni-app 拦截器核心流程解析
前端·javascript·微信小程序
云枫晖5 分钟前
破壁前行:深度解析前端跨域的本质与实战
前端·浏览器
文心快码BaiduComate6 分钟前
代码·创想·未来——百度文心快码创意探索Meetup来啦
前端·后端·程序员
小白64029 分钟前
前端梳理体系从常问问题去完善-框架篇(Vue2&Vue3)
前端
云和数据.ChenGuang14 分钟前
vue中构建脚手架
前端·javascript·vue.js
渣哥16 分钟前
面试官最爱刁难:Spring 框架里到底用了多少经典设计模式?
javascript·后端·面试
千与千寻酱20 分钟前
排列与组合在编程中的实现:从数学概念到代码实践
前端·python
q_191328469528 分钟前
基于RuoYi框架+Mysql的汽车进销存后台管理系统
数据库·vue.js·spring boot·mysql·汽车·个人开发·若依
朱昆鹏31 分钟前
如何通过sessionKey 登录 Claude
前端·javascript·人工智能
wdfk_prog32 分钟前
klist 迭代器初始化:klist_iter_init_node 与 klist_iter_init
java·前端·javascript