Skip to content

a294465800/vue-debounce

Repository files navigation

vue-debounce-component

simple debounce component for vue

Installation

npm i -S vue-debounce-component

Usage

// main.js
import Vue from 'vue';
import App from './app.vue';
import Debounce from 'vue-debounce-component';

Vue.use(Debounce)

new Vue({
  el: '#app',
  render: h => h(App)
})
<template>
  <Debounce :timeout="300" events="input">
    <input type="text" @input="handleInput" />
  </Debounce>

  
  <Debounce :timeout="300" events="input">
    <my-input type="text" @input="handleInput2"></my-input>
  </Debounce>
</template>

<script>
export default {
  methods: {
    handleInput(val){
      console.log(val, 'val')
    },
    
    handleInput2(val){
      console.log(val, 'val2')
  }
}
</script>

Props

timeout default unit is ms, so :timeout="300" means 300ms, you can specify unit like 1s.ms and s supports only.

events use to specify the event you want to debounce. It allows you to set multiple events using :events="['input','change','click']".

name type default example
timeout String/Number 300 300/300ms/0.3s
events String/Array / input/['input','change']

About

vue debounce component

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published