当前位置:网站首页>函数节流与函数防抖
函数节流与函数防抖
2022-08-08 16:14:00 【何故逸】
今天我们来学习函数节流与函数防抖,那为什么要使用函数节流与函数防抖呢?
因为某些代码会在没有间断的情况下连续重复执行(例如:滚动条事件,只要滚动条稍稍一变化,那代码就会执行一次) ,这样就会导致效率非常低,为了提高效率就要控制某个函数在一定时间内执行的次数,这就是函数节流与函数防抖的本质。
1.函数防抖
函数防抖的本质是将代码延迟执行,在一定的时间间隔后执行(这里我们假设时间间隔为500毫秒),那么下一次代码也会在500毫秒以后执行,在500毫秒内永远只执行最后触发的一次。
//debounce()函数进入页面立即执行
// debounce()必须返回函数因为事件只能调用函数
function debounce(callback,time=300){
let t;
return function(){ //返回的是一个逻辑,处理防抖
clearTimeout(t); //在500毫秒这个时间段内又滚动了一次就要把上一次的定时器清除
t=setTimeout(callback,time);
}
}
// 绑定滚动条事件
window.onscroll = debounce(function(){//监听滚动条
console.log("调用了一次");
},500);
//将debounce函数赋值给了滚动条事件,刚一上来就赋值,相当于刚一上来就调用了一次 同时我们给debounce函数定义了两个参数,一个为函数,另一个为时间
效果如下:
QQ录屏20220807215035
其本质就是:1.在第一次调用debounce()函数的时候设置一个定时器(t),在指定的时间(time)后运行代码(callback)。
2.在第二次调用debounce()函数的时候会清除上一次的定时器(t),并重新设置一个名为(t)的定时器
3.在以上操作中,如果时间间隔(500毫秒)已经过了,即定时器已经执行过了,那么上面的操作就没有任何意义了。如果时间间隔没有过,则用一个新的定时器替换上一个定时器
4.其主要在于只有在执行函数的请求停止了间隔时间之后才执行。
应用:回到顶部效果
2.函数节流
在500毫秒的时间中只执行第一次的,即用第二次调用函数时的时间戳减去上一次调用函数时的时间戳,如果值大于500毫秒就可以继续执行,如果小于500毫秒,就不能调用函数
function throlle(callback,time){
let lasttime=new Date().getTime();
return function(){ //因为将throlle()函数赋值给了事件,事件执行的是函数,所以要返回函数
let now=new Date().getTime();
if((now-lasttime)>=time){
fun();
lasttime=now;
}
}
}
window.onscroll = throlle(fun,500);//将函数赋值给了事件,所以一开始就调用了throlle()函数
function fun(){
console.log("函数调用一次");
}
应用:按钮点击
边栏推荐
- 手把手教你uniapp接入聊天IM即时通讯功能-源码分享
- 使用 PyGame 的冒泡排序可视化工具
- Kubernetes二进制部署高可用集群
- codeforces 444C DZY Loves Colors
- The realization of the salary slip issuing function of WeChat public account + web background
- Share these new Blender plugins that designers must not miss in 2022
- GHOST工具访问数据库
- Superset 1.2.0 安装
- redis的详细介绍与操作命令
- [Unity entry plan] Unity instance - how to protect data members through encapsulation in C#
猜你喜欢
Nuxt - 网站接入 51LA 网站统计(详细教程)
携手数字创新 共筑国产生态 7月份AntDB与5款产品完成互认证
使用 FasterTransformer 和 Triton 推理服务器加速大型 Transformer 模型的推理
‘xxxx‘ is declared but its value is never read.Vetur(6133)
赶紧进来修内功!!!带你认识C语言中各种进制数和原码反码补码.
基于ECS实现一分钟自动化部署【华为云至简致远】
pytorch安装过程中出现torch.cuda.isavailable()=False问题
10分钟快速入门RDS【华为云至简致远】
Take you to play with the "Super Cup" ECS features and experiment on the pit [HUAWEI CLOUD is simple and far]
【有奖征文 第13期】至简致远,“云”响世界,大胆秀出你的华为云技术主张,高额激励等你拿
随机推荐
最高法院关于婚姻案件诉讼程序的一些解答
【云原生】云原生相关技术概念总结
leetcode 31. 下一个排列(实现next_permutation 函数)
Power BI简介
赶紧进来修内功!!!带你认识C语言中各种进制数和原码反码补码.
mmdetection最新版食用教程(一):安装并运行demo及开始训练coco
[Unity entry plan] Use the double blood bar method to control the blood loss speed of the damage area
EMQ畅谈IoT数据基础软件开源版图,引领本土开源走向全球
Go 语言 Strconv 库常用方法
egg(二十):fs读取本地的txt文件
带你玩转“超大杯”ECS特性及实验踩坑【华为云至简致远】
查询接口 - 树形菜单查询接口实现
leetcode/删除链表的倒数第n个结点
All volunteers V853 chip Tina RTSP environment set up
redis设计与实现 笔记(一)
在 Fedora 上使用 SSH 端口转发
jupyter notebook hide & show all output
Introduction to Power BI
web自动化无头模式
2022年中国全民健身发展白皮书