当前位置:网站首页>防抖和节流
防抖和节流
2022-07-31 05:20:00 【前端备忘录】
为什么要防抖
有的操作是高频触发的,但是其实触发一次就好了,比如我们短时间内多次缩放页面,那么我们不应该每次缩放都去执行操作,应该只做一次就好。再比如说监听输入框的输入,不应该每次都去触发监听,应该是用户完成一段输入后在进行触发。
总结:等用户高频事件完了,再进行事件操作。
防抖怎么做

设计思路:事件触发后开启一个定时器,如果事件在这个定时器限定的时间内再次触发,则清除定时器,在写一个定时器,定时时间到则触发。
function debounce(fn, delay){
let timer = null;
return function(){
clearTimeout(timer);
timer = setTimeout(()=> {
fn.apply(this, arguments);
}, delay)
}
}
为什么要节流
防抖存在一个问题,事件会一直等到用户完成操作后一段时间在操作,如果一直操作,会一直不触发。比如说是一个按钮,点击就发送请求,如果一直点,那么请求就会一直发布出去。这里正确的思路应该是第一次点击就发送,然后上一个请求回来后,才能再发。
**总结:**某个操作希望上一次的完成后再进行下一次,或者希望隔一段时间触发一次。
节流怎么做

设计思路:我们可以设计一种类似控制阀门一样定期开放的函数,事件触发时让函数执行一次,然后关闭这个阀门,过了一段时间后再将这个阀门打开,再次触发事件。
function throttle(fn, delay){
let valid = true;
return function(){
if(valid) {
setTimeout(()=> {
fn.apply(this, arguments);
valid = true;
}, delay)
valid = false;
}
}
}
总结
- 防抖和节流相同点:
防抖和节流都是为了阻止操作高频触发,从而浪费性能。
- 防抖和节流区别:
防抖是让你多次触发,只生效最后一次。适用于只需要一次触发生效的场景。
节流是让你的操作,每隔一段时间触发一次。适用于多次触发要多次生效的场景。
如果内容有错误的地方欢迎指出(觉得看着不理解不舒服想吐槽也完全没问题);如果有帮助,欢迎点赞和收藏
边栏推荐
- 力扣.三数之和/四数之和
- Oracle入门 08 - Linux 系统远程登录维护
- fdisk分区,gdisk添加磁盘,parted进行磁盘分区,parted新增分区,临时挂载和永久挂载
- 实现二叉树的基本操作
- Oracle入门 13 - Linux文件目录类命令
- 递归访问目录,定义嵌套函数,打印斐波那契数列,对列表进行排序,map函数计算列表,filter函数过滤,reduce计算1~100的和
- Unity软件中UGUI和NGUI的多语言开发
- TCP与UDP协议的区别,以及TCP的三次握手和四次挥手
- Oracle入门 12 - Linux 磁盘分区及LVM实战
- 十分钟教你玩转分支语句!!!!!小白速进,新手福利!!
猜你喜欢
随机推荐
UE5 最新动态虚幻引擎全新版本引爆互联网
Webrtc从理论到实践一:初识
堆和栈的区别
Openssl一键自签证书
cenos7配置IP,配置IP不生效
Oracle入门 11 - Linux 开关机及系统进程命令
VRchat_udon脚本介绍:傻瓜式教程教你如何实现VRchat地图的功能
DOM操作-事件的绑定与解绑
C语言数组的深度分析
性能测试概述
npm install出现node错误
VS2019配置配置项目属性自定义输出目录与中间目录
力扣.找到打字符串中所有字母异位词
常见网络攻击与防御方法
物联网时代网络安全成第一大关
ROS subscription to multiple topics time synchronization problem
基础配置--IP地址--主机名--域名
windows下mysql忘记密码登录,并创建用户
超详细!!!让你了解冒泡排序的底层逻辑和思想
等待,信息打印,浏览器操作,键盘事件









