element-ui中远程搜索select

本文介绍如何使用 Element UI 的 select 组件实现一个支持多选、模糊搜索及输入提示的下拉框功能。文章详细展示了通过 Vue.js 实现这一功能的具体代码,并讨论了在实现过程中遇到的问题及解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目中有下拉框,需求:获取焦点,可以让用户选择,也可以让用户在输入框中输入,实现模糊搜索,也可以多选。因为使用element-ui,所以就使用了select的高级用法,需求如下图所示


我们以代码的形式进行呈现

<template>
    <div class="short-visit">
      <el-form :model="ruleForm" :rules="rules" ref="ruleForm" label-width="130px" class="demo-ruleForm" v-if="textFlag">
        <el-form-item label="出访国家(地区)" prop="foreignName" class="nation-select">
          <el-select
            style="min-height: 30px;line-height: 30px;height: auto;"
            class="selects"
            v-model="ruleForm.foreignName"
            multiple
            filterable
            remote
            reserve-keyword
            :multiple-limit="3"
            @focus="tt"
            :remote-method="remoteMethod"
            placeholder="请选择国家">
            <el-option
              v-for="item in options4"
              :key="item.value"
              :label="item.label"
              :value="item.value">
            </el-option>
          </el-select>
          <div class="titles">提示:如出访台湾地区,请按照国际处网页赴台流程及所需材料进行线下审批。</div>
        </el-form-item>

        
        <el-form-item class="submitBtn">
          <el-button type="primary" @click="submitForm('ruleForm')">提交</el-button>
        </el-form-item>
    </div>
</template>

<script>
import api from '../../utils/api'
export default {
  name: 'short-visit',
  data () {
      uploadUrl: '',
      ruleForm: {
        foreignName: [], // 出访国家
      },
      options4: [],
      list: [],
      rules: {
        foreignName: [
          { required: true, message: '请选择国家', trigger: 'change' }
        ]
      }
    }
  },
  created () {
    /**
     * 国家的请求
     * */
    this.getContryData()
    
  },
  methods: {
    
    /**
     * 数据的提交
     * */
    submitForm (formName) {
      this.$refs[formName].validate((valid) => {
        if (valid) {
          
          this.$confirm('是否确认提交', {
            confirmButtonText: '确定',
            cancelButtonText: '取消',
            type: 'warning',
            center: true
          }).then(() => {
            
          }).catch(() => {
          })
        } else {
          return false
        }
      })
    },
    /**
     * 国家
     * */
    getContryData () {
      api.getContrys().then((res) => {
        // console.log(res)
        // console.log(res.data.code)
        if (res.data.code === 0) {
          for (var i = 0; i < res.data.data.length; i++) {
            let obj = {}
            obj.value = res.data.data[i].codeLabel
            obj.codeValue = res.data.data[i].codeValue
            this.list.push(obj)
          }
          // console.log(this.ruleForm.foreignName)
        }
      })
    },
    /**
     * 选择国家获取焦点
     * */
    tt () {
      this.options4 = this.list
      console.log(this.options4)
    },
    /**
     * 选择国家
     * */
    remoteMethod (query) {
      console.log(query)
      if (query !== '') {
        this.loading = true
        setTimeout(() => {
          this.loading = false
          this.options4 = this.list.filter(item => {
            return item.value.toLowerCase()
              .indexOf(query.toLowerCase()) > -1
          })
        }, 200)
      } else {
        this.options4 = []
      }
    }
  }
}
</script>

<style rel="stylesheet/scss" lang="scss">
   
</style>

上面当el-select获取焦点的时候,我们把请求到的数据复制给option4,页面做一个渲染,当我们输入实现模糊搜索的时候,使用的是过滤。

我在处理数据的时候,push进去的是value跟codeValue,在做循环,我们理所当然用的value跟codeValue。当我们只输入的时候,没有问题,但我们只选择的时候,也没有任何问题,但是有一部分是输入搜索得到,有一部分是选择得到,就会出现问题,input中你选择的值就不合适了。经过检查,最终以上面代码的解决方法解决,是没有任何问题的。

### Element Plus 中 `el-select` 组件导致页面卡死的解决方案 当处理大量选项时,`el-select` 可能会由于性能问题而导致页面卡顿甚至卡死。针对此情况,可以考虑以下几种优化措施: #### 使用虚拟滚动技术 对于拥有大量数据项的选择框,推荐使用带有虚拟滚动功能的新版选择器组件 `el-select-v2`。尽管该版本存在一些已知缺陷,比如全选逻辑上的 bug[^1],但对于大多数场景而言,其显著提升了渲染效率。 如果遇到特定情况下仍发生阻塞,则需进一步排查具体原因并针对性调整配置参数或尝试其他变通办法来规避潜在风险点。 #### 减少一次性加载的数据量 通过分页机制或是懒加载的方式逐步获取所需展示的内容列表而非一开始就全部读入内存中显示出来;这不仅能够有效缓解前端资源占用过高所引发的一系列连锁反应,同时也改善用户体验感。 ```html <template> <div class="select-container"> <!-- 启用远程搜索特性 --> <el-select v-model="selectedValue" filterable remote :remote-method="fetchOptions" placeholder="请选择..." clearable > <el-option v-for="(item, index) in options" :key="index" :label="item.label" :value="item.value" /> </el-select> </div> </template> <script setup lang="ts"> import { ref } from 'vue'; const selectedValue = ref(''); let currentPage = 1; const pageSize = 10; // 假设这是异步请求接口函数 async function fetchOptions(queryString: string): Promise<void> { // 清空现有选项 options.value.length = 0; try { const response = await api.get('/options', { params: { page: currentPage, size: pageSize, q: queryString || undefined, }, }); // 更新本地状态中的选项数组 options.value.push(...response.data.items); // 如果还有更多数据可加载则增加当前页码以便下次调用继续拉取下一页内容 if (response.data.hasMore) { currentPage += 1; } } catch (error) { console.error('Failed to load options:', error); } } // 初始化首次查询操作以填充初始可见区域内的条目 fetchOptions(''); </script> ``` 上述代码片段展示了如何利用 Vue 的组合式 API 实现基于关键字过滤以及按需增量加载远端服务器上存储的大规模候选集的功能[^2]。
评论 9
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值