Вы можете добавить debouncing к функции, которая делает вызовы API.Демонтер может быть реализован с setTimeout
и clearTimeout
, так что новые вызовы задерживаются и отменяет любой ожидающий вызов:
methods: {
fetchEntriesDebounced() {
// cancel pending call
clearTimeout(this._timerId)
// delay new call 500ms
this._timerId = setTimeout(() => {
this.fetch()
}, 500)
}
}
Такой методможет быть привязан к наблюдателю на search-input
подпорке v-autocomplete
:
<template>
<v-autocomplete :search-input.sync="search" />
</template>
<script>
export default {
data() {
return {
search: null
}
},
watch: {
search (val) {
if (!val) {
return
}
this.fetchEntriesDebounced()
}
},
methods: { /* ... */ }
}
</script>
демо