位置: 编程技术 - 正文

javascript函数的节流[throttle]与防抖[debounce](javascript函数的作用)

编辑:rootadmin

推荐整理分享javascript函数的节流[throttle]与防抖[debounce](javascript函数的作用),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript函数的定义,javascript函数的作用域,javascript函数的命名规则,javascript函数的关键词,javascript函数的定义,javascript函数的定义会包括一个称为形参,javascript函数的定义,javaScript函数的定义和调用的性能消耗,内容如对您有帮助,希望把文章链接给更多的朋友!

防抖和节流

窗口的resize、scroll,输入框内容校验等操作时,如果这些操作处理函数较为复杂或页面频繁重渲染等操作时,如果事件触发的频率无限制,会加重浏览器的负担,导致用户体验非常糟糕。此时我们可以采用debounce(防抖)和throttle(节流)的方式来减少触发的频率,同时又不影响实际效果。

这两个东西都是为了项目优化而出现的,官方是没有具体定义的,他们的出现主要是为了解决一些短时间内连续执行的事件带来性能上的不佳和内存的消耗巨大等问题;

像这类事件一般像 scroll keyup mousemove resize等等,短时间内不断的触发,在性能上消耗是非常大的,尤其是一些改变DOM结构的操作;

节流[throttle]与防抖[debounce]非常相似,都是让上述这类事件在规定的事件从不断的去触发更改成为规定的时间内触发多少次;

节流[throttle]

节流通俗来解释就比如我们水龙头放水,阀门一打开,水哗哗的往下流,这个秉着勤俭节约的优良传统美德,我们要把水龙头关小点,最好是如我们心意按照一定规律在某个时间间隔内一滴一滴的往下滴,这,,,好吧这就是我们节流的概念;

换成函数来说,使用setTimeout方法,给定两个时间,后面的时间减去前面的时间,到达我们给定的时间就去触发一次这个事件,这么说太笼统的,我们看下面的函数,这里我们以【scroll】为例;

------------------------

------------------------

javascript函数的节流[throttle]与防抖[debounce](javascript函数的作用)

通过以上的函数,我们就可以做到节流的效果,在规定的每毫秒触发一次,当然时间可以自定义,根据需求来;

防抖[debounce ]

写代码之前,我们先清楚一下防抖的概念,不知道大家有没有做过电脑端两边悬浮广告窗口的这么一个东西,当我们拖动滚动条的时候,两边的广告窗口会因为滚动条的拖动,而不断的尝试着去居于中间,然后你就会看到这两个窗口,不停的抖啊抖;

一般这种就叫抖动了,我们要做的就是防止这种抖动,称为防抖[debounce ];

那这里防抖思想就是当我们拖动完成之后,两边的窗口位置再重新去计算,这样,就会显得很平滑,看着很舒服了,最主要的操作DOM结构的次数就大大减少了;

优化了页面性能,降低了内存消耗,不然你像IE这种比较老点版本的浏览器,说不定就直接给你蹦了

用书面一点的说法就是,在某个事件没有结束之前,函数不会执行,当结束之后,我们给定延时时间,然他在给定的延时时间之后再去执行这个函数,这就是防抖函数;

来看代码:

思路就是在函数执行之前,我们先清除定时器,如果函数一直执行,就会不断的去清除定时器中的方法,知道我们操作结束之后,函数才会执行;

其实书写的方式有很多,主要还是思路的问题,大家写的多了,自然就知道了;

用途

当我们做keyup像后台请求检验的时候,可以使用防抖函数,不然我们每按一次键盘就请求一次,请求太频繁,这样当我们结束按键盘的时候再去请求,请求少很多了,性能自然不用说; resize 窗口大小调整的时候,我们可以采用防抖技术也可以使用节流; mousemove 鼠标移动事件我们既可以采用防抖也可以使用节流; scroll 滚动条触发的事件,当然既可以采用防抖也可以采用节流; 连续高频发的事件都可以采用这两种方式去解决,优化页面性能;

具体的采用哪一种更较为合适,主要还是看你的业务需求,好了,本篇就到这里了,感谢大家阅读;希望对大家的学习有所帮助,也希望大家多多支持积木网。

layui.js实现的表单验证功能示例 本文实例讲述了layui.js实现的表单验证功能。分享给大家供大家参考,具体如下:该示例可针对文本框,手机,邮箱,textarea等格式进行验证首先引入如

layer实现关闭弹出层刷新父界面功能详解 本文实例讲述了layer实现关闭弹出层刷新父界面功能。分享给大家供大家参考,具体如下:layer是一款近年来备受青睐的web弹层组件,她具备全方位的解

layui框架中layer父子页面交互的方法分析 本文实例讲述了layui框架中layer父子页面交互的方法。分享给大家供大家参考,具体如下:layer是一款近年来备受青睐的web弹层组件,官网地址是:

标签: javascript函数的作用

本文链接地址:https://www.jiuchutong.com/biancheng/369802.html 转载请保留说明!

上一篇:Js判断H5上下滑动方向及滑动到顶部和底部判断的示例代码(js判断div是否有滚动条)

下一篇:layui.js实现的表单验证功能示例(layui nodejs)

  • 怎样理解一般纳税人
  • 购买办公用品属于会计对象吗
  • 出口结汇必须要开票吗
  • 全年交多少税可以退
  • 培训产生的费用
  • 个人社保由单位承担的可以进福利费吗
  • 企业向个人借款需要交印花税吗
  • 如何设置处理器个数如何设置显示器超频
  • 短期借款会计核算
  • 固定资产改变用途进项转出
  • 投资资产包括哪些会计科目
  • 长期债券是指偿还期限超过几个月的债券
  • 企业住房维修基金怎么交
  • 购买职工宿舍用品账务处理
  • 小规模发票什么样子
  • 中央空调 付款
  • 工程交税必须在工程地点交吗
  • 贸易公司购进原材料会计分录
  • 作废发票 红字发票
  • 地税评为d级纳税人是指
  • 中国人民银行保险公司
  • 不得抵扣且未抵扣什么意思
  • 税法递延纳税
  • 公司三季度亏损20个亿这股票值得买吗
  • 盈余公积什么时候调整
  • 维修费属于印花税
  • 充值卡多长时间到账
  • win7桌面快捷键是什么
  • 常见内存大小
  • 资产处置收益期末有余额吗
  • 企业接受捐赠的固定资产账务处理
  • 用代管资金付出的钱
  • 商家说补发什么意思
  • 刚毕业的学生可以买学生票吗
  • 电脑安全模式有声音吗
  • php 数组
  • 如何在win11上安装旧版ie
  • php字符串定义
  • scards32.exe - scards32是什么进程 有什么用
  • 哪些合同不属于担保合同
  • 坦桑尼亚塞伦盖蒂公园有什么动物
  • 一般纳税人销售自己使用过的汽车
  • php+mysql+ajax实现单表多字段多关键词查询的方法
  • 科目余额表和资产负债表的金额不一致的原因
  • 快速上手:华硕路由器的wireguard服务器
  • 投资性房地产在资产负债表中的列示
  • 服务业销售收入
  • 自产自销免税农产品需要缴纳印花税吗
  • 法人给对公账户转账
  • 企业的业务招待费属于什么费用
  • 利息收入为什么冲减财务费用
  • 小规模没有税控怎么开普票
  • 企业所得税核定管理办法
  • 哪几种进项税额允许抵扣
  • 资产减值准备如何影响利润
  • 印花税的征税对象和计税依据
  • 税务稽查补缴上年所得税分录
  • 当事人对付款时间没有约定或者约定不明的
  • 收回股权投资
  • 12月多开的发票,可以明年1月份入账吗?
  • 购买设备的运费增值税计入成本吗
  • 出售固定资产属于什么收入
  • 利用rpm安装软件包时,应使用命令选项
  • win2000系统
  • win8不能启动
  • xp系统优化的方法
  • gacrunner.exe是什么
  • windows启动很慢很慢
  • 生产运维管理
  • win7无法删除d盘
  • 批处理自动登录有密码的程序
  • python数据结构教程
  • linux特殊符号转义
  • python文件文件夹操作
  • 安卓手机电驴
  • android使用红杏代理更新sdk
  • 湖北省电子税务局操作指南
  • 营销服务协议书范本
  • 怎样查询上一年的国税
  • 滨州市望海花园北侧规划
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设