vue-delayed-input-delegate
v0.1.4
Published
Emits one 'delayedInput' event for series of input events followed by each other with short interval
Downloads
21
Maintainers
Readme
vue-delayed-input-delegate
VueJs component.
Emits one "delayedInput" event for series of events followed by each other with short interval. For example, fast text printing will emit one "delayedInput" after short print pause. This is intended for "auto save" or "auto validate" logic.
It's not input itself - it is a wrapper element, listening for "input" or "change" events propagated by nested elements. So you can use one "delegate" for group of inputs.
Demo
mkant.ru/mink-js/vue-delayed-input-delegate/
Installation
npm i vue-delayed-input-delegate --S
import delayedInputDelegate from "vue-delayed-input-delegate";
Usage
<delayed-input-delegate @delayedInput="autoSave">
<!-- put any input elements here ... -->
<input v-model="title" />
<textarea v-model="text"></textarea>
</delayed-input-delegate>
Custom Inputs
If input component does not emit standart DOM event and thus, it does not propagates up through DOM, you can "touch" delegate "by hands" via ref
attribute.
<delayed-input-delegate ref="delegate" @delayedInput="autoSave">
<custom-input v-model="someVar" @input="$refs.delegate.touch()" />
</delayed-input-delegate>