在vue中使用防抖

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在vue中使用防抖相关的知识,希望对你有一定的参考价值。

参考技术A

防抖是 在事件被触发n秒后再执行回调函数,如果在这n秒内又被触发,则重新计时。
常规写法如下

由上面改写过来变成:

vue 防抖和节流

vue 没有内置支持防抖和节流,但可以使用 Lodash 等库来实现。

如果某个组件仅使用一次,可以在 methods 中直接应用防抖:

<script src="https://unpkg.com/lodash@4.17.20/lodash.min.js"></script>
<script>
  Vue.createApp({
    methods: {
      // 用 Lodash 的防抖函数
      click: _.debounce(function() {
        // ... 响应点击 ...
      }, 500)
    }
  }).mount('#app')
</script>

但是,这种方法对于可复用组件有潜在的问题,因为它们都共享相同的防抖函数。为了使组件实例彼此独立,可以在生命周期钩子的 created 里添加该防抖函数:

app.component('save-button', {
  created() {
    // 用 Lodash 的防抖函数
    this.debouncedClick = _.debounce(this.click, 500)
  },
  unmounted() {
    // 移除组件时,取消定时器
    this.debouncedClick.cancel()
  },
  methods: {
    click() {
      // ... 响应点击 ...
    }
  },
  template: `
    <button @click="debouncedClick">
      Save
    </button>
  `
})

以上是关于在vue中使用防抖的主要内容,如果未能解决你的问题,请参考以下文章

防抖

JS防抖和节流

防抖和节流

防抖和节流

JavaScript 防抖和节流的实现

JavaScript 防抖和节流的实现