导致问题出现的原因是 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;
}),