el-select下拉菜单如何可以手输入内容

<el-select v-model="form.region" placeholder="请选择活动区域"> <el-option label="区域一" value="shanghai"></el-option> <el-option label="区域二" value="beijing"></el-option> </el-select>下拉菜单如何可以手输入内容并且根据输入的内容对应显示下拉内容

复制代码
<template>
  <div style="padding: 20px;">
    <!-- 带输入过滤的下拉选择框 -->
    <el-select
      v-model="form.region"
      placeholder="请选择活动区域/手动输入搜索"
      filterable          <!-- 开启输入过滤功能 -->
      :filter-method="filterRegion"  <!-- 自定义过滤方法 -->
      clearable           <!-- 可选:增加清空按钮 -->
      style="width: 300px;"
    >
      <el-option
        v-for="item in regionOptions"
        :key="item.value"
        :label="item.label"
        :value="item.value"
      ></el-option>
    </el-select>
  </div>
</template>

<script>
export default {
  data() {
    return {
      form: {
        region: ''  // 绑定的选中值
      },
      // 下拉选项数据源(建议抽离,便于维护)
      regionOptions: [
        { label: '区域一', value: 'shanghai' },
        { label: '区域二', value: 'beijing' },
        // 可扩展更多选项
        { label: '区域三', value: 'guangzhou' },
        { label: '区域四', value: 'shenzhen' }
      ]
    };
  },
  methods: {
    // 自定义过滤方法:val 是输入框的实时输入内容
    filterRegion(val) {
      // 如果输入为空,显示所有选项
      if (!val) return true;
      // 过滤逻辑:匹配 label(中文名称)或 value(值),不区分大小写
      return this.regionOptions.filter(item => {
        return item.label.toLowerCase().includes(val.toLowerCase()) 
            || item.value.toLowerCase().includes(val.toLowerCase());
      });
    }
  }
};
</script>

关键注意点

  1. filterable 是基础,开启后才会显示输入框;
  2. 自定义 filter-method 时,参数是输入框的实时值,需返回布尔值(或过滤后的数组);
  3. 若需要纯输入(不限制下拉选项),可结合 allow-create 属性(Element Plus 支持,Element UI 需自定义);
  4. 远程搜索时,建议增加输入防抖(比如延迟 300ms 再请求接口),避免频繁请求。

这样就能实现「手动输入内容 + 根据输入过滤下拉选项」的核心需求了。

相关推荐
小陈工1 小时前
Python Web开发入门(十七):Vue.js与Python后端集成——让前后端真正“握手言和“
开发语言·前端·javascript·数据库·vue.js·人工智能·python
xiaotao1315 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉5 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
彧翎Pro6 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
小码哥_常6 小时前
解锁系统设置新姿势:Activity嵌入全解析
前端
之歆6 小时前
前端存储方案对比:Cookie-Session-LocalStorage-IndexedDB
前端
哟哟耶耶6 小时前
vue3-单文件组件css功能(:deep,:slotted,:global,useCssModule,v-bind)
前端·javascript·css
是罐装可乐6 小时前
深入理解“句柄(Handle)“:从浏览器安全到文件系统访问
前端·javascript·安全
华科易迅7 小时前
Vue如何集成封装Axios
前端·javascript·vue.js
康一夏7 小时前
Next.js 13变化有多大?
前端·react·nextjs