uniapp实现事件级防抖

背景:

uniapp项目中所有页面跳转都会触发多次点击事件,导致页面排版错乱或其他问题

在utils文件夹下创建debounce.js文件

javascript 复制代码
export const Debounce = (fn, wait) => {
	let delay = wait || 500
	let timer
	return function() {
		let args = arguments;
		if (timer) {
			clearTimeout(timer)
		}

		let callNow = !timer
		timer = setTimeout(() => {
			timer = null
		}, delay)
		if (callNow) fn.apply(this, args)
	}
}

使用方式

在需要使用防抖的页面引入方法

javascript 复制代码
import { Debounce } from "@/utils/debounce.js";

页面使用

javascript 复制代码
// 原方法
methodName(type) {
	console.log(type)
}
// 修改后方法
methodName: Debounce(function(type) {
	// 逻辑代码
	console.log(type)
}, 1000),

注意: 不要使用箭头函数 () => {}, 会导致this获取不到

如果有更合理或者更好的防抖方法,希望可以多多指教

相关推荐
小码哥_常7 小时前
从0到1:Android组件化架构搭建秘籍
前端
忆江南7 小时前
iOS 应用启动流程与优化详解
前端
itslife7 小时前
前端架构模式思考
前端·架构
Wect7 小时前
JSX & ReactElement 核心解析
前端·react.js·面试
雨落Re7 小时前
从递归组件到 DSL 引擎:我造了一个让 AI 能"搭 UI"的运行时
前端·vue.js
Maxkim7 小时前
前端工程化落地指南:pnpm workspace + Monorepo 核心用法与实践
前端·javascript·架构
大漠_w3cpluscom7 小时前
使用 clip-path: shape() 创建 Squircle 形状
前端·css·weui
大怪v19 小时前
AI抢饭?前端佬:我要验牌!
前端·人工智能·程序员
新酱爱学习19 小时前
字节外包一年,我的技术成长之路
前端·程序员·年终总结
小兵张健19 小时前
开源 playwright-pool 会话池来了
前端·javascript·github