最近接到的一个新需求:实时搜索文档关键字并高亮显示,听起来好难的样子,仔细分析起来其实也蛮简单的。
实现思路
通过 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>`);
},
}
如此便实现了搜索关键字并高亮显示。
如果项目中有多处用到这个功能的,也可以用自定义指令封装一下高亮的方法,此处我略去了,有需要的自行实现吧。