解决Element-ui input 在搜狗输入法下,限制输入数字时先输入汉字后无法绑定的问题

在使用 Element UI 的 el-input 组件时,如果需要限制用户只能输入数字,并且确保在输入汉字后再输入数字能够正确绑定,以下提供两种解决方案,需要根据情况适当修改

  1. 监听 input 事件并处理值

    可以在 el-input 组件上监听 input 事件,并在事件处理函数中对用户的输入进行处理,确保只保留数字。

    vue 复制代码
    <template>
      <el-input v-model="inputValue" @input="handleInput"></el-input>
    </template>
    <script>
    export default {
      data() {
        return {
          inputValue: '',
        };
      },
      methods: {
        handleInput(value) {
          const pattern = /^[1-9]\d*$/;
          if (pattern.test(value)) {
            this.inputValue = value;
          } else {
            const num = value.match(/\d+/g);
            this.inputValue = num ? num.join("") : "";
          }
        },
      },
    };
    </script>

    在这个示例中,当用户输入时,handleInput 方法会被调用。该方法使用正则表达式来检查输入值是否为正整数。如果是,就更新 inputValue;如果不是,就提取输入中的数字并更新 inputValue

  2. 使用 blur 事件重新赋值

    第二种方法是在 el-input 组件上使用 blur 事件,当输入框失去焦点时,将输入框的值重新赋值给绑定的变量。这样可以确保即使输入了非数字字符,最终绑定的值也只包含数字。以下是一个示例代码:

    vue 复制代码
    <template>
      <el-input
        v-model="inputValue"
        @blur="inputValue = $event.target.value.replace(/[^\d]/g, '')"
      ></el-input>
    </template>
    <script>
    export default {
      data() {
        return {
          inputValue: '',
        };
      },
    };
    </script>

    在这个示例中,当输入框失去焦点时,会触发 blur 事件,并将输入框的值通过正则表达式处理后重新赋值给 inputValue

相关推荐
「、皓子~11 分钟前
后台管理系统的诞生 - 利用AI 1天完成整个后台管理系统的微服务后端+前端
前端·人工智能·微服务·小程序·go·ai编程·ai写作
就改了14 分钟前
Ajax——在OA系统提升性能的局部刷新
前端·javascript·ajax
凌冰_16 分钟前
Ajax 入门
前端·javascript·ajax
京东零售技术31 分钟前
京东小程序JS API仓颉改造实践
前端
奋飛40 分钟前
TypeScript系列:第六篇 - 编写高质量的TS类型
javascript·typescript·ts·declare·.d.ts
老A技术联盟40 分钟前
从小白入门,基于Cursor开发一个前端小程序之Cursor 编程实践与案例分析
前端·小程序
风铃喵游44 分钟前
构建引擎: 打造小程序编译器
前端·小程序·架构
sunbyte1 小时前
50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | ThemeClock(主题时钟)
前端·javascript·css·vue.js·前端框架·tailwindcss
小飞悟1 小时前
🎯 什么是模块化?CommonJS 和 ES6 Modules 到底有什么区别?小白也能看懂
前端·javascript·设计
浏览器API调用工程师_Taylor1 小时前
AOP魔法:一招实现登录弹窗的全局拦截与动态处理
前端·javascript·vue.js