IOS 下输入中文没有触发 keyup,导致绑定不了数据

导致问题出现的原因是 IOS 自带输入法输入中文时不触发 KEYUP 事件,因为不触发 KEYUP 事件,导致文本框最后一个字符没有执行双向绑定

解决方法:

1.在提交前手工去执行KEYUP事件。

2.使用 js 判断值是否一致,不一致把 js 文本框值赋值给 vue 绑定值。

html 里面进行双向绑定,结果会发现调起 IOS 中文键盘的时候,输入的值和 v-model=”insName” 绑定的值 “insName”的值不一样。

<div class="edit-item">
    <div class="content">
        <span class="title name ">投保人姓名</span>
        <input type="text"  v-model="insName" ref="name"> <!-- v-model数据双向绑定, ref便于后期选择该输入框 --> 
    </div>
</div>

所以这里监听键盘 keyup 事件,在失去焦点的时候使 insName 的值变为输入框的值

this.$refs.name.addEventListener('blur', function(){
      self.insName = self.$refs.name.value;
}),

猜你喜欢

转载自blog.csdn.net/zhaileilei1/article/details/77705399