项目中有下拉框,需求:获取焦点,可以让用户选择,也可以让用户在输入框中输入,实现模糊搜索,也可以多选。因为使用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中你选择的值就不合适了。经过检查,最终以上面代码的解决方法解决,是没有任何问题的。

GitHub 加速计划 / eleme / element
54.06 K
14.63 K
下载
A Vue.js 2.0 UI Toolkit for Web
最近提交(Master分支:3 个月前 )
c345bb45 7 个月前
a07f3a59 * Update transition.md * Update table.md * Update transition.md * Update table.md * Update transition.md * Update table.md * Update table.md * Update transition.md * Update popover.md 7 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐