事件节流函数封装层

事件节流函数封装层

 以下场景往往由于事件频繁被触发,因而频繁执行DOM操作、资源加载等重行为,导致UI停顿甚至浏览器崩溃。

  1. window对象的resize、scroll事件

  2. 拖拽时的mousemove事件

  3. 射击游戏中的mousedown、keydown事件

  4. 文字输入、自动完成的keyup事件

  实际上对于window的resize事件,实际需求大多为停止改变大小n毫秒后执行后续处理;而其他事件大多的需求是以一定的频率执行后续处理。针对这两种需求就出现了debounce和throttle两种解决办法。

二、什么是debounce                            

   1. 定义

  如果用手指一直按住一个弹簧,它将不会弹起直到你松手为止。

      也就是说当调用动作n毫秒后,才会执行该动作,若在这n毫秒内又调用此动作则将重新计算执行时间。

   接口定义

1 /**
2 * 空闲控制 返回函数连续调用时,空闲时间必须大于或等于 idle,action 才会执行
3 * @param idle   {number}    空闲时间,单位毫秒
4 * @param action {function}  请求关联函数,实际应用需要调用的函数
5 * @return {function}    返回客户调用函数
6 */
7 debounce(idle,action)

2.简单实现

 1 var debounce = function(idle, action){
 2   var last
 3   return function(){
 4     var ctx = this, args = arguments
 5     clearTimeout(last)
 6     last = setTimeout(function(){
 7         action.apply(ctx, args)
 8     }, idle)
 9   }
10 }

三、什么是throttle                              

   1. 定义

  如果将水龙头拧紧直到水是以水滴的形式流出,那你会发现每隔一段时间,就会有一滴水流出。

  也就是会说预先设定一个执行周期,当调用动作的时刻大于等于执行周期则执行该动作,然后进入下一个新周期。

      接口定义:

1 /**
2 * 频率控制 返回函数连续调用时,action 执行频率限定为 次 / delay
3 * @param delay  {number}    延迟时间,单位毫秒
4 * @param action {function}  请求关联函数,实际应用需要调用的函数
5 * @return {function}    返回客户调用函数
6 */
7 throttle(delay,action)

   2. 简单实现

 1 var throttle = function(delay, action){
 2   var last = 0;
 3     return function(){
 4     var curr = +new Date()
 5     if (curr - last > delay){
 6       action.apply(this, arguments)
 7       last = curr 
 8     }
 9   }
10 }    

http://www.cnblogs.com/fsjohnhuang/p/4147810.html

http://www.cnblogs.com/dolphinX/p/3403821.html

http://www.admin10000.com/document/1124.html

【前端性能】高性能滚动 scroll 及页面渲染优化

转载于:https://www.cnblogs.com/suoking/p/5481808.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109027.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • IntelliJ IDEA 快捷键整合(大全)

    IntelliJ IDEA 快捷键整合(大全)IntelliJIDEA快捷键整合大全1.代码标签输入完成后,按Tab,生成代码。2.查询快捷键3.其他快捷键4.svn快捷键5.调试快捷键6.重构7.其他1.代码标签输入完成后,按Tab,生成代码。Ctrl+Alt+O优化导入的类和包Alt+Insert生成代码(如get,set方法,构造函数等)或者右键(Generate)fori/sout/psvm+TabCtrl…

    2022年5月15日
    60
  • python 爱心代码_python浪漫代码

    python 爱心代码_python浪漫代码动态心型importturtleimporttimedefLittleHeart():foriinrange(200):turtle.right(1)turtle.forward(2)love=’Ilove草莓’turtle.setup(width=900,height=500)turtle.color(‘red’,’red’)turtle.pensize(3)turtle.speed(50)turtle.

    2022年10月13日
    0
  • 利用Redis实现高并发计数器

    利用Redis实现高并发计数器业务需求中经常有需要用到计数器的场景:譬如一个手机号一天限制发送5条短信、一个接口一分钟限制多少请求、一个接口一天限制调用多少次等等。使用Redis的Incr自增命令可以轻松实现以上需求。以一个接口一天限制调用次数为例: /** *是否拒绝服务 *@return */ privatebooleandenialOfService(StringuserId){ longc…

    2022年5月24日
    249
  • 重定向和转发的区别及应用_重定向是什么意思

    重定向和转发的区别及应用_重定向是什么意思请求转发:客户首先发送一个请求到服务器端,服务器端发现匹配的servlet,并指定它去执行,当这个servlet执行完之后,它要调用getRequestDispacther()方法,把请求转发给指定的student_list.jsp,整个流程都是在服务器端完成的,而且是在同一个请求里面完成的,因此servlet和jsp共享的是同一个request,在servlet里面放的所有东西,在stude…

    2022年9月8日
    0
  • Xenu-死链接检测工具「建议收藏」

    Xenu-死链接检测工具「建议收藏」Xenu是一款深受业界好评,并被广泛使用的死链接检测工具。时常检测网站并排除死链接,对网站的 SEO 非常重要,因为大量死链接存在会降低用户和搜索引擎对网站的信任。我们推荐的死链接检测工具Xenu主要具有以下特征:需要下载安装,不到1M大小,用户界面非常简洁,操作简单。检测彻底:能够检测到图片、框架、插件、背景、样式表、脚本和java程序中的链接。报告形式合理多样

    2022年7月23日
    9
  • springboot集成Thymeleaf(二)「建议收藏」

    springboot集成Thymeleaf(二)「建议收藏」一、基本语法使用1、传递对象:@Controllerpublic class MyController1 { @Autowired private HeroService heroService; @RequestMapping(“/hello”) public String hello(Model model) { …

    2022年6月13日
    29

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号