千家信息网

JavaScript如何实现防抖与节流

发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这篇文章主要介绍了JavaScript如何实现防抖与节流,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。概念防抖:点击N次提交按钮,只有
千家信息网最后更新 2025年01月19日JavaScript如何实现防抖与节流

这篇文章主要介绍了JavaScript如何实现防抖与节流,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

概念

防抖:点击N次提交按钮,只有最后一次会发出请求。减少无效请求的次数。

节流:每点击一次按钮,都会失效一段时间。降低触发的频率。

实现

/*防抖时限内,只有最后一次调用会执行*/function debounce(func, interval = 0) {        let timer;        return function () {                if (timer) {                        clearTimeout(timer);                }                timer = setTimeout(() => {                        func()                }, interval)        }}/*节流执行之后会失效一段时间*/function throttle(fn, interval=0, immediate=true) {        let valid = true        return function () {                if (!valid) {                        return                }                valid = false                if (immediate) {                        fn()                        setTimeout(() => {                                valid = true;                        }, interval)                } else {                        setTimeout(() => {                                fn()                                valid = true;                        }, interval)                }        }}

测试

function say() {        console.log(1)}var a = debounce(say, 1000)var b = throttle(say, 1000)var c = throttle(say, 1000, false)

效果:

防抖。

节流,立即执行。

节流,延时执行。

注意事项

原理:闭包。每调用一次都会对应一个闭包。

不能够像下面这样写:

不然:

感谢你能够认真阅读完这篇文章,希望小编分享的"JavaScript如何实现防抖与节流"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

测试 篇文章 只有 按钮 时间 闭包 一测 事项 价值 兴趣 原理 同时 效果 时限 更多 朋友 概念 次数 注意事项 知识 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 网络安全技术与工程是网络工程吗 sql2008数据库拆分 郧阳区正规软件开发案例 公安局召开网络安全监督检查会议 密码编码学与网络安全第四 上海企业网络技术服务价目 南京计算机软件开发服务费 上海夺创网络技术有限公司怎么样 写含有三个级的数据库 软件开发文档写作示例 于洪芬 软件开发中心 图书发行信息管理系统数据库 《网络安全伴我行》初一作文 java数据库创建图书信息 网络安全隐患排查记录隐患 网络安全证书有问题可以看吗 服务器面板定制 前端开发与数据库 外服手游英雄联盟服务器卡 中国网络安全攻防靶场 进一步强化网络安全 学生观看网络安全课总结 bug修复后怎么应用到服务器 风险研判依据网络安全 玻璃服务器是什么情况 中国有多少台服务器 手机管理服务器工具 网络安全防护小技巧文章 数据库系统概念第七版 网络安全是攻防对抗
0