vue3搜索显示出对应的搜索结果,结果中与关键字对应的字体高亮

效果

vue3代码

<template>
  <div>
    <el-input v-model="title" @input="sea" style="width: 400px;border: 1px solid black;"></el-input>
    <ul v-for="item in newlist" :key="item.id">
        <li v-html="highlight(item.name)"></li>
    </ul>
  </div>
</template>

<script lang='ts' setup>
  import { computed, ref } from 'vue'
  let title=ref('')
  const sea=()=>{
    //搜索
    console.log(title.value);
  }
  const list=ref([
    {
      id:1,
      name:'自行车'
    },
    {
      id:2,
      name:'山地车'
    },
    {
      id:3,
      name:'公路车'
    },
    {
      id:4,
      name:'电动车'
    },
    {
      id:5,
      name:'苹果手机'
    },
    {
      id:6,
      name:'华为手机'
    },
    {
      id:7,
      name:'小米手机'
    }
  ])

  const newlist=computed(()=>{
    //如果未输入内容,则ul下不显示任何内容
    if(title.value=='') return;
    else{
      return list.value.filter(item=>item.name.includes(title.value))
    }
  })
  interface list{
    id:number,
    name:string
  }

  const highlight=(text:string)=>{
    if(!title.value) return text;
    //将输入的内容替换成span标签,并设置样式
    //正则表达式:gi 表示全局匹配,忽略大小写
    return text.replace(new RegExp(title.value,'gi'),`<span style="color:blue">${title.value}</span>`)
  }
 
</script>

<style lang='less' scoped>
</style>

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值