前端通过Vue自己实现输入框模糊筛选数据,并将筛选结果展示

业务场景是后端返回数据,前端通过input输入框进行模糊筛选,并将筛选结果展示在下面
在这里插入图片描述
例如接口返回的数据为:
[{id:1, name:“课程1”}
{id:2, name:“课程2”}
{id:3, name:“续报”}]
input输入框输入: 续报
结果显示为: 续报
在这里插入图片描述

input输入框输入: 课程
结果显示为: 课程1 和 课程2
在这里插入图片描述

<el-input
          placeholder="请输入内容"
          v-model="input"
          @blur="validateCounts"
        >
          <i slot="prefix" class="el-input__icon el-icon-search"></i>
        </el-input>

将目标数据进行渲染

<div
          class="content-item"
          v-for="(item, index) in recommendedOrders"
          :key="index"
        >{{item.name}}</div>

将接口数据进行遍历,对满足筛选条件的数据进行存储,然后在页面进行渲染

 validateCounts () {
 	  // 输入的内容
      let valueInput = this.input || ''
      // 存储筛选后的结果
      const temp = [];
      // 将接口数据进行遍历
      (this.recommendedOrdersBack || []).forEach((item) => {
     if(item.name.indexOf(valueInput) >= 0){
          temp.push(item)
       } 
      })
      // 将筛选结果的数据存储
      this.recommendedOrders = temp
    },
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值