前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >函数节流详解

函数节流详解

作者头像
江咏之
发布2022-06-16 18:42:01
2760
发布2022-06-16 18:42:01
举报
文章被收录于专栏:技术社区

一、什么是函数节流(throttle)

首先函数节流的概念是什么?

限制一个函数在一定时间内只能执行一次。

举个栗子: 接下来,我给大家举个栗子

个人理解 函数节流就是fps(射击)游戏的射速,就算一直按着鼠标射击,也只会在规定射速内射出子弹。

二、为什么需要函数节流

前端开发过程中,有一些事件或者函数,会被频繁地触发(短时间按内多次触发),最常见的例如,onresize,scroll,mousemove ,mousehover 等,这些事件的触发频率很高,不做限制的话,有可能一秒之内执行几十次、几百次,如果在这些函数内部执行了其他函数,尤其是执行了操作 DOM 的函数(浏览器操作 DOM 是很耗费性能的),那不仅会造成计算机资源的浪费,还会降低程序运行速度,甚至造成浏览器卡死、崩溃。这种问题显然是致命的。

除此之外,重复的 ajax 调用不仅可能会造成请求数据的混乱,还会造成网络拥塞,占用服务器带宽,增加服务器压力,显然这个问题也是需要解决的。

三、函数节流如何解决上述问题

根据上面对问题的分析,细细思索,问题的解决方案就呼之欲出了。

主要实现思路就是通过 setTimeout 定时器,通过设置延时时间,在第一次调用时,创建定时器,先设定一个变量true,写入需要执行的函数。第二次执行这个函数时,会判断变量是否true,是则返回。当第一次的定时器执行完函数最后会设定变量为false。那么下次判断变量时则为false,函数会依次运行。目的在于在一定的时间内,保证多次函数的请求只执行最后一次调用。

四、函数节流的代码实现

根据以上分析,我们对“函数节流”进行代码实现,如下:

当鼠标在页面上移动,只要鼠标移动了,我们就在控制台打印一个随机数。

常规方法:

代码语言:javascript
复制
function handle(){
    console.log(Math.random());
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021-11-05,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、什么是函数节流(throttle)
  • 二、为什么需要函数节流
  • 三、函数节流如何解决上述问题
  • 四、函数节流的代码实现
相关产品与服务
云服务器
云服务器(Cloud Virtual Machine,CVM)提供安全可靠的弹性计算服务。 您可以实时扩展或缩减计算资源,适应变化的业务需求,并只需按实际使用的资源计费。使用 CVM 可以极大降低您的软硬件采购成本,简化 IT 运维工作。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档