Commit 90eb1e19 authored by Boik's avatar Boik Committed by baiyaaaaa

Autocomplete: fix problem when input with Chinese input method (#4393)

parent 92b4156a
...@@ -9,6 +9,9 @@ ...@@ -9,6 +9,9 @@
:size="size" :size="size"
:icon="icon" :icon="icon"
:on-icon-click="onIconClick" :on-icon-click="onIconClick"
@compositionstart.native="handleComposition"
@compositionupdate.native="handleComposition"
@compositionend.native="handleComposition"
@change="handleChange" @change="handleChange"
@focus="handleFocus" @focus="handleFocus"
@blur="handleBlur" @blur="handleBlur"
...@@ -71,6 +74,7 @@ ...@@ -71,6 +74,7 @@
data() { data() {
return { return {
isFocus: false, isFocus: false,
isOnComposition: false,
suggestions: [], suggestions: [],
loading: false, loading: false,
highlightedIndex: -1 highlightedIndex: -1
...@@ -100,9 +104,17 @@ ...@@ -100,9 +104,17 @@
} }
}); });
}, },
handleComposition(event) {
if (event.type === 'compositionend') {
this.isOnComposition = false;
this.handleChange(event.data);
} else {
this.isOnComposition = true;
}
},
handleChange(value) { handleChange(value) {
this.$emit('input', value); this.$emit('input', value);
if (!this.triggerOnFocus && !value) { if (this.isOnComposition || (!this.triggerOnFocus && !value)) {
this.suggestions = []; this.suggestions = [];
return; return;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment