el-select使用filter-method实现自定义过滤

最近有个任务要用el-select来自定义过滤,发现有很多细节,网上搜的很多不够严谨,情况考虑不全,此处给出完整解决方案

实现DEMO

  • filter-method input里输入时才会触发,和input上的change事件一样,它只会传一个参数:检索的文字。要结合各种情况,自己过滤出optionsFilter给option赋值

  • 容易遗漏的情况:当输入一段和下面选项不匹配的文字时,此时过滤的结果列表是空,这时点击空白处,检索文字会自动清空,过滤结果保持是空,会影响下一次搜索,所以需要配合@focus来重置过滤结果

html 复制代码
<template>
  <div>
    <el-select v-model="seledMan"
               clearable
               filterable
               size="small"
               :filter-method="filterMan"
               placeholder="请选择"
               @change="searchFirstList"
               @clear="filterMan"
               @focus="filterMan()">
      <el-option v-for="item in optionsFilter"
                 :key="item.value"
                 :label="item.label"
                 :value="item.value">
      </el-option>
    </el-select>
  </div>
</template>
<script>
export default {
  data() {
    return {
      optionsOrigin: [
        { value: 'zhangsan', label: '张三' },
        { value: 'lisi', label: '李四' },
        { value: 'wangwu', label: '王五' },
        { value: 'zhaoliu', label: '赵六' },
      ],
      optionsFilter: [],

      seledMan: '',
    }
  },
  methods: {
    filterMan(query) {
      console.log('触发过滤')
      if (!query) {
        this.optionsFilter = this.optionsOrigin
        return
      }
      const queryStr = query.toLowerCase()
      const filterList = this.optionsOrigin.filter((option) => {
        const nameZh = option.label,
          namePY = option.value.toLowerCase()
        return nameZh.includes(queryStr) || namePY.includes(queryStr)
      })
      this.optionsFilter = filterList
    },

    searchFirstList() {
      //选择人之后,重置页面为第一页,触发检索
      console.log('selDone', this.seledMan)
    },
  },
  created() {
    // 也可以是接口获取optionsOrigin后,同时赋给optionsFilter
    this.optionsFilter = [...this.optionsOrigin]
  },
  mounted() {},
  computed: {},
}
</script>
<style lang="scss" scoped>
</style>
相关推荐
多则惑少则明12 小时前
Vue开发系列——自定义组件开发
前端·javascript·vue.js
用户2506949216112 小时前
next框架打包.next文件夹部署
前端
程序猿小蒜12 小时前
基于springboot的校园社团信息管理系统开发与设计
java·前端·spring boot·后端·spring
一叶难遮天12 小时前
开启RN之旅——前端基础
前端·javascript·promise·js基础·es6/ts·npm/nrm
申阳12 小时前
Day 4:02. 基于Nuxt开发博客项目-整合 Inspira UI
前端·后端·程序员
程序猿_极客13 小时前
【期末网页设计作业】HTML+CSS+JavaScript 猫咪主题网站开发(附源码与效果演示)
前端·css·html·课程设计·网页设计作业
IT古董13 小时前
【前端】从零开始搭建现代前端框架:React 19、Vite、Tailwind CSS、ShadCN UI 完整实战教程-第1章:项目概述与技术栈介绍
前端·react.js·前端框架
有点笨的蛋13 小时前
从零搭建小程序首页:新手也能看懂的结构解析与实战指南
前端·微信小程序
爱宇阳13 小时前
Vue3 前端项目 Docker 容器化部署教程
前端·docker·容器
Irene199113 小时前
前端缓存技术和使用场景
前端·缓存