vue防抖节流,全局定义,使用

防抖和节流

  • 防抖节流的作用都是用于防止函数被多次调用,
  • 区别在于,如果一个用户一直触发这个函数,每次触发的间隔都小于wait,防抖的情况下只会调用一次,而节流的情况会每隔一段一段时间调用函数
  • 防抖在间隔时间内被触发会重新计时,执行最后一次
  • 节流在间隔时间内只执行一次,第一次

防抖方法

防抖在间隔时间内被触发会重新计时,执行最后一次

javascript 复制代码
let timer=null
export function debouce(fn, time=1000){
 if(timer!=null){
    clearTimeout(timer)
 }
 timer=setTimeout(()=>{
	typeof fn==='function'&&fn.apply(this)
 },time)
}

节流

节流在间隔时间内只执行一次,第一次

javascript 复制代码
let flag=false;
export const throttle=(fn,time=300)=>{
	if(flag) clearTimeout(timer)
	flag=true
	timer=setTimeout(()=>{
		typeof fn==='function'&&fn().apply(this)
		flag=false
	},time)
}

main.js中全局引入

javascript 复制代码
import {debouce, throttle} from "xx.js"

Vue.prototype.$D = { debouce, throttle }

使用

javascript 复制代码
@click="$D.debouce(()=>自己的方法名())"
相关推荐
JieE2122 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
runnerdancer3 小时前
LLM是怎么处理messages数组的,提示词缓存又是什么
前端·agent
陈随易3 小时前
VSCode的Copilot扩展支持接入DeepSeek,Kimi了!
前端·后端·程序员
我不是外星人5 小时前
有了 Harness Engineering ,真的还需要研发工程师吗?
前端·后端·ai编程
candyTong5 小时前
RTK 技术原理:一次典型会话里,80% 上下文是怎么省下来的
javascript·后端·架构
IT_陈寒7 小时前
JavaScript的闭包把我坑惨了,说好的内存会自动回收呢?
前端·人工智能·后端
Jackson__8 小时前
分享一个横向滚动案例,带悬停暂停,通用性很强
前端
MariaH9 小时前
git rebase的使用
前端
_柳青杨9 小时前
深入理解 JavaScript 事件循环
前端·javascript
阡陌Jony9 小时前
关于前端性能优化的一些问题:
前端