Vue - Element 选择器 el-select 既可以选择下拉又可以手动输入文本功能(手动输入的值只能是数字 并且支持4位小数)

Vue - Element 选择器 el-select 既可以选择下拉又可以手动输入文本功能(手动输入的值只能是数字 并且支持4位小数)

备注

filterable 下拉框开启快速搜索功能

no-match-text 当输入的内容在下拉框中找不到时;下拉框提示的文字

@handFocus 触发输入框

@change 点击下拉选项

@visible-change下拉框出现/隐藏时触发

@keyup.native 输入搜索内容实时触发(在此方法中对输入格式做限制)

template部分

bash 复制代码
 <el-select
    v-model="min"
    filterable
    placeholder="最小值"
    no-match-text="可手动输入"
    style="width:90px;margin-right: 4px;"
    ref="inputSelectMin" 
    @focus="handFocus" 
    @change="handChange"
    @visible-change="handleVisibleChange"
    @keyup.native="inputData"
>
    <el-option
        v-for="item in minToleranceTypeList"
        :key="item.codeValue"
        :label="item.name"
        :value="item.codeValue" 
     />
</el-select>

逻辑部分( el-select 实现 既可以输入内容又可以快速选择)

bash 复制代码
  private isSelectChange:boolean= false;// 判断是选择下拉选项 默认未选择
  handChange (data:any) {
    this.min = data
    this.isSelectChange = true;
  }
  handleVisibleChange(val:any){
    if(!val){
      let input = this.$refs[ref]?.$children[0].$refs.input;
      input.blur();
    }
  }
  handFocus(){
    let input = this.$refs.inputSelectMin?.$children[0].$refs.input;
    input.blur= ()=> {
      if (!this.isSelectChange) {
        this.min = input.value;
      }
      this.isSelectChange = false
    }
  }
  // 输入框只能输入数字,最大可支持4位小数
  inputData(val:any){
    let strData = val.srcElement.value
    if (/^(\.)/.test(strData)) {
      // 匹配第一个字符是否为 .
      val.srcElement.value = strData.substring(
        strData.lastIndexOf(".") + 1,
        strData.length
      );
      return;
    }
    if (/[^\d.]+/.test(strData)) {
      // 匹配中间是否插入了字母,等其他字符
      val.srcElement.value = strData.replace(/[^\d.]+/, "");
      return;
    }
    if (/([0-9]\d*)(\.\d*){2,}/.test(strData)) {
      // 匹配是否有多个 . --恶意输入
      val.srcElement.value = "";
      return;
    }
    if (/^([0-9]\d{0,7}(\.\d{5,}))$/.test(strData)) {
      // 小数点后是否超过了3位-恶意输入
      val.srcElement.value = strData.substring(0, strData.lastIndexOf(".") + 5);
      return;
    }
    val.srcElement.value = strData.substring(0, strData.length);
  }
相关推荐
鱼樱前端1 小时前
今天介绍下最新更新的Vite7
前端·vue.js
coder_pig2 小时前
跟🤡杰哥一起学Flutter (三十四、玩转Flutter手势✋)
前端·flutter·harmonyos
万少2 小时前
01-自然壁纸实战教程-免费开放啦
前端
独立开阀者_FwtCoder2 小时前
【Augment】 Augment技巧之 Rewrite Prompt(重写提示) 有神奇的魔法
前端·javascript·github
yuki_uix2 小时前
AI辅助网页设计:从图片到代码的实践探索
前端
我想说一句2 小时前
事件机制与委托:从冒泡捕获到高效编程的奇妙之旅
前端·javascript
陈随易2 小时前
MoonBit助力前端开发,加密&性能两不误,斐波那契测试提高3-4倍
前端·后端·程序员
汤姆Tom2 小时前
JavaScript reduce()函数详解
javascript
小飞悟2 小时前
你以为 React 的事件很简单?错了,它暗藏玄机!
前端·javascript·面试
中微子2 小时前
JavaScript 事件机制:捕获、冒泡与事件委托详解
前端·javascript