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

时间:2024-10-10 07:12:22

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

<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