vue3+elementPlus el-select组件同时支持label和value模糊查询

element ui的select组件设置filterable后, 默认支持的是通过label来进行过滤搜索,

官方文档上提供了filter-method来自定义搜索方法

想要下拉框数据里同时显示label和value可以用插槽的方式

visible-change(下拉框出现/隐藏时触发)的事件来实现功能.

功能要求:下拉框数据展示label+value,选中后的数据只展示label

代码如下:

<el-select class="flex6" placeholder="请输入代码或名称" v-model="config.seach" filterable :filter-method="value => (config.keyword = value)" @visible-change="() => (config.keyword = '')" >
       <el-option v-for="item in list" :key="item.value" :label="item.label" :value="item.value"  >{{item.value+'-'+item.label}}</el-option>
 </el-select> 
import {ref,reactive,computed} from 'vue'
let config=reactive({
        seach:'',
        keyword:'',
        basicList:[{ label: 'Timmy', value: '000001.SH' },
            { label: 'Judd', value: '000002.SH' },
            { label: 'Dequan', value: '000003.SH' },
            { label: 'Olin', value: '000004.SH' },
            { label: 'Bear', value: '000005.SH' },
            { label: 'Caesar', value: '000006.SH' },
            { label: 'Davi', value: '000007.SH' },
            { label: 'Wisdom', value: '000008.SH' },
            { label: 'Pavel', value: '000009.SH' },
            { label: 'Alain', value: '000011.SH' }],
      })
  	let list=computed(() => {//侧边栏二级名字
      if (config.keyword === '') {
            return config.basicList;
      } else {
        return config.basicList.filter(item => {
          return ( 
            String(item.label)
              .toUpperCase()
              .includes(config.keyword.toUpperCase()) ||
            String(item.value)
              .toUpperCase()
              .includes(config.keyword.toUpperCase())
          )  
        })
      }
    })

 注意:遍历的时候的key值不要用index,因为数组是事实变换的会无法找到对应的项,最好是用value值

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值