vue中使用防抖和节流

一、防抖

定义:频繁操作防止抖动,在操作后 n 秒内不操作,才触发事件,若继续操作,则重新计时

场景:

  1. 输入框输入
  2. 缩放resize

/**  utils.js
*    immediate 是否开始立即执行
*/
function debounce(func, delay = 300, immediate = false) {
    let timer = null
    return function() {
        if (timer) {
            clearTimeout(timer)
        }
        if (immediate && !timer) {
            func.apply(this, arguments)
        }
        timer = setTimeout(() => {
         func.apply(this, arguments)
        }, delay)
    }
}

二、节流

定义:频繁操作稀释函数执行,频繁操作时,每隔n秒才触发一次

场景:

  1. 鼠标点击,mousedown,mousemove单位时间只执行一次
  2. 滚动事件,懒加载、滚动加载、加载更多或监听滚动条位置
  3. 防止高频点击提交,防止表单重复提交
// utils.js
function throttle (func, delay = 300) {    
    let prev = 0
    return function() {
        let now = Date.now()
        if ((now - prev) >= delay) {
            func.apply(this, arguments)
            prev = Date.now()
        }
    }
}

三、vue中的使用方法

方法1:写在公共方法utils里引入

import { debounce } from 'utils'
methods: {
    appSearch:debounce(function(e.target.value){
        this.handleSearch(value)
    }, 1000),
    handleSearch(value) {
        console.log(value)
    }
}

方法2:写在当前vue文件中

data: () => {
  return {
    debounceInput: () => {}
  }
},
methods: {
  showApp(value) {
    console.log('value', value)
  },
  debounce(func, delay = 300, immediate = false) {
    let timer = null
    return function() {
        if (timer) {
            clearTimeout(timer)
        }
        if (immediate && !timer) {
            func.apply(this, arguments)
        }
        timer = setTimeout(() => {
         func.apply(this, arguments)
        }, delay)
    }
  }
},
mounted() {
  this.debounceInput = this.debounce(this.showApp, 1000)      
},

猜你喜欢

转载自blog.csdn.net/ShIcily/article/details/121673227