Vue2使用定时器和闭包实现防抖和节流函数。将函数放入util.js中,供具体功能在methods中调用

Vue2使用定时器和闭包实现防抖和节流函数。

将函数放入util.js中,供具体功能在methods中调用。<br/

参考文档:

文章目录

防抖函数实现 方式1:

使用 this[fnName]()

util: debounce代码

javascript 复制代码
let  util = {};

util.debounce = function (fnName, delay = 500){
    let timer = null
    return function () {
        console.count('防抖函数执行')
        if(timer){
            clearTimeout(timer);
        }
        timer = setTimeout(()=>{
            this[fnName]();
        }, delay);
    }
}

export default util;

功能中调用

html 复制代码
  <Button @click="clickMe">我是一个防抖的按钮</Button>
javascript 复制代码
import util from "@/components/util";
export default {
    methods:{
		funcTest() {
		  console.log('实际函数执行 start-----------')
		  console.count('实际执行次数')
		},
		clickMe: util.debounce('funcTest', 500),
	},
	beforeDestroy() {
		this.clickMe = null;
	},
}

执行结果

通过gif可以看到,我点击了四次按钮,最后一次点击0.5秒后才实际执行函数。

防抖函数实现 方式2:

使用 fn.apply(this, arguments)

在网上的资料中,这种实现是最多的,但是把防抖函数放到util.js中,程序就会报错:起都起不来。

Uncaught TypeError: Cannot read properties of undefined (reading 'funcTest')

代码

javascript 复制代码
util.debounce2 = function(fn, delay = 500) {
    let timer = null;
    return function() {  // flag1
        console.count('防抖函数执行')
        console.log(fn)
        if (timer) {
            clearTimeout(timer);
        }
        timer = setTimeout(() => {
            fn.apply(this, arguments);
        }, delay);
    }
}

clickMe : util.debounce2 (this.funcTest, 500),

功能中调用(存在错误)

javascript 复制代码
 clickMe: util.debounce2(this.funcTest, 500),

报错:

校正后的正确调用

研究了vue中调用lodash的防抖函数的实现方式给了我灵感,我个人把他粗浅的解释为: util.debounce2是一个"外地人",它无法找到funcTest()这个函数,当然,使用调用方中data中的任何一个变量也都会报错。所以需要使用clickDebounce本地化一下。

javascript 复制代码
    clickDebounce: util.debounce2 ( function (){   // flag2
      this.funcTest()
    },500),
    funcTest() {
      console.log('实际函数执行 start-----------')
      console.count('实际执行次数')
    },
     /* clickMe: util.debounce2(this.funcTest, 500),*/
     clickMe (){
       this.clickDebounce()
    },

注意:代码 flag1和flag2中的 function(){}不能替换为箭头函数()=>{},因为箭头函数没有this,还是会报undefined的错误。

校正后的执行结果

通过结果,可以看到:可以实现防抖

节流函数实现

每个一段时间执行一次函数。避免一个函数在短时间内多次执行

代码

javascript 复制代码
util.throttle = function(fn, delay = 500) {
    let lastCall = 0;
    return function() {
        console.count('节流函数执行')
        const now = Date.now();
        if (now - lastCall < delay) {
            return;
        }
        lastCall = now;
        return fn.apply(this, arguments);;
    }
}

调用

javascript 复制代码
    clickThrottle: util.throttle(function () {
      this.funcTest()
    }, 1000),
    funcTest() {
      console.log('实际函数执行 start-----------')
      console.count('实际执行次数')
    },
     /* clickMe: util.debounce2(this.funcTest, 500),*/
    clickMe() {
      this.clickThrottle()
    },

结果

通过gif可知,尽管点击频率很快,但是实际函数每隔1秒执行一次。

相关推荐
matlab_xiaowang2 小时前
Redux 入门:JavaScript 可预测状态管理库
开发语言·javascript·其他·ecmascript
前端摸鱼匠4 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker5 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
Linsk6 小时前
Java和JavaScript的关系真是雷峰和雷峰塔的关系吗?
java·javascript·oracle
当时只道寻常6 小时前
浏览器文本复制到剪贴板:企业级最佳实践
javascript
Alice-YUE7 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀9 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
莎士比亚的文学花园9 小时前
Linux驱动开发(3)——设备树
开发语言·javascript·ecmascript
01漫游者10 小时前
JavaScript函数与对象增强知识
开发语言·javascript·ecmascript
threelab11 小时前
Three.js 代码云效果 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能