vue3 对象数组 关键字高亮

  const data = reactive({
        searkey: '建筑',
        list: [{
            title: '地下室顶板钢筋堆载及建筑加工对砼结构产生的影响都有哪些',
            time: '2022年5月6日 6:44'
        }, {
            title: '中国建筑加工业的前景与未来',
            time: '2022年5月6日 6:44'
        }, {
            title: 'BIM模型在建筑业的应用以及轻量化处理后产生的冗余',
            time: '2022年5月6日 6:44'
        }, {
            title: '建筑加工材料',
            time: '2022年5月6日 6:44'
        }],
    })   



function lighting(val: any) {
        let keyword = data.searkey
        if (val.indexOf(keyword) !== -1) {
            return val.replace(keyword, `<span style='color:red'>${keyword}</span>`)
        } else {
            return val
        }
    }

    data.list.map((item) => {
        item.title = lighting(item.title)
    })

页面:

要用v-html 解析 replace 的 html

<div class="one-list" v-for="(item,index) in data.list" :key="index">
     <p class="list-title" v-html="item.title"></p>
 </div>

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值