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 再请求接口),避免频繁请求。

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

相关推荐
小徐_23331 小时前
Wot UI 2.2.0 发布:Button 新增 subtle,VideoPreview 预览体验继续增强
前端·微信小程序·uni-app
天蓝色的鱼鱼3 小时前
关于 CSS 你可能不知道的属性,但关键时刻很有用
前端·css
泯泷4 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
妙码生花4 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
泯泷4 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
团团崽_七分甜4 小时前
Spring Boot 核心知识点总结
前端
lichenyang4534 小时前
从一个按钮开始,理解 ASCF 框架到底在做什么
前端
古夕5 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js
朦胧之5 小时前
页面白屏卡住排查方法
前端·javascript