Replies: 1 comment
-
| 想要没延迟只能在input事件中直接改input的value <script lang="ts" setup>
import { ref } from 'vue'
const msg = ref('message')
const handleInput = (e: Event) => {
  const el = e.target as HTMLInputElement
  msg.value = el.value = el.value.replace(/[^\d]/g, '')
}
</script>
<template>
  <input type="text" :value="msg" @input="handleInput" />
  <div>{{msg}}</div>
</template><script lang="ts" setup>
import { ref, useTemplateRef , watch } from 'vue'
const msg = ref('message')
const el = useTemplateRef('input')
watch(msg, () => {
  if(!el.value) return
  msg.value = el.value.value = msg.value.replace(/[^\d]/g, '')
})
</script>
<template>  
  <input ref="input" type="text" v-model="msg" />
  <div>{{msg}}</div>
</template> | 
Beta Was this translation helpful? Give feedback.
                  
                    0 replies
                  
                
            
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment
  
        
    
Uh oh!
There was an error while loading. Please reload this page.
-
简要
我希望利用defineModel实现一个手机号输入框,并且它具有输入校验功能(过滤非法字符)
简单来说,就是不希望用户能够输入规则以外的字符(比如字母/符号)又或者是总体文本长度.
尝试
我尝试了set方法,但是它return的值不会立即反馈到input本身(会有一个奇怪的延迟).
所以我不得不使用nextTick和一些判断,重新给input赋值
想法
所以我希望,defineModel的set能够解决这个问题,又或者能够增加一个类似filter/check字段来实现类似功能
代码
这是目前我想出的变相解决方案,仅供参考
Beta Was this translation helpful? Give feedback.
All reactions