vue 搜索文本让搜索的字体高亮显示

首先用到了ant design vue的折叠板replace方法(replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。)
这个折叠组件的hander支持字符串写法,支持solt写法。现在用的是solt写法,字符串写法就直接hander=‘item.name’

 <a-collapse accordion @change="changePanel" activeKey="activeKey">
   <a-collapse-panel>
     v-for="(item, index) in examineContent"
     :key="index"
     :hander='item.name'
     :extra="`包含检查内容${item.contentCount}项`"
   	</a-collapse-panel>
   </a-collapse>
   /**这个是solt写法*/
 <template slot="header">
   <span v-html="item.name">
     {{item.name}}
   </span>
 </template>

接下来就是方法了,在搜索的时候把需要你搜索的值高亮(比如你搜索的是安全,如果折叠面板的hander里面的内容是安全生产放第一,那么安全这俩个字就高亮显示)

// 这个就是我需要替换的文本,this.project就是你input搜索框搜索的值,比如搜索安全
var patt1 = new RegExp(this.project);
// patt1打印出来的值/安全/
this.examineContent.map(examineItem => {
/** 这儿把整个数据循环一下,然后让他每一项的name用replace的方法给转换一下
`<span style='color: red'>${this.project}</span>`用的es6模板字符串,转换以后然后再把每一项的转换好的值赋值给他的每一项,html用v-html写,要不然会把标签也显示出来。*/
// patt1就是你即将要替换的文本,第二个参数就是你需要替换的文本
  examineItem.name = examineItem.name.replace(patt1,`<span style='color: red'>${this.project}</span>`)
  });

再次提醒html一定要用v-html写,要不然会渲染出来标签,转换以后一定要把转换以后的值赋给当前的值。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

好苦呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值