[improvement] Field: not update v-model during IME composition

This commit is contained in:
陈嘉涵 2019-05-30 17:16:59 +08:00
parent d67cec269f
commit efa1142589
2 changed files with 33 additions and 5 deletions

View File

@ -2,6 +2,10 @@
### [v2.0.0-beta.3](https://github.com/youzan/vant/tree/v2.0.0-beta.3)
##### Field
- 优化输入体验,输入法拼写过程中不再会触发`v-model`更新
##### IndexBar
- 新增`sticky`属性

View File

@ -50,7 +50,11 @@ export default sfc({
computed: {
showClear() {
return (
this.clearable && this.focused && this.value !== '' && isDef(this.value) && !this.readonly
this.clearable &&
this.focused &&
this.value !== '' &&
isDef(this.value) &&
!this.readonly
);
},
@ -95,6 +99,11 @@ export default sfc({
},
onInput(event) {
// not update v-model when composing
if (event.target.composing) {
return;
}
this.$emit('input', this.format(event.target));
},
@ -140,7 +149,9 @@ export default sfc({
const { keyCode } = event;
const allowPoint = String(this.value).indexOf('.') === -1;
const isValidKey =
(keyCode >= 48 && keyCode <= 57) || (keyCode === 46 && allowPoint) || keyCode === 45;
(keyCode >= 48 && keyCode <= 57) ||
(keyCode === 46 && allowPoint) ||
keyCode === 45;
if (!isValidKey) {
preventDefault(event);
@ -191,7 +202,14 @@ export default sfc({
...this.$attrs,
readonly: this.readonly
},
on: this.listeners
on: this.listeners,
// add model directive to skip IME composition
directives: [
{
name: 'model',
value: this.value
}
]
};
if (this.type === 'textarea') {
@ -256,11 +274,17 @@ export default sfc({
>
<div class={bem('body')}>
{this.renderInput()}
{this.showClear && <Icon name="clear" class={bem('clear')} onTouchstart={this.onClear} />}
{this.showClear && (
<Icon name="clear" class={bem('clear')} onTouchstart={this.onClear} />
)}
{this.renderRightIcon()}
{slots('button') && <div class={bem('button')}>{slots('button')}</div>}
</div>
{this.errorMessage && <div class={bem('error-message', this.errorMessageAlign)}>{this.errorMessage}</div>}
{this.errorMessage && (
<div class={bem('error-message', this.errorMessageAlign)}>
{this.errorMessage}
</div>
)}
</Cell>
);
}