当前位置:首页 > 编程技术 > 正文内容

JS 性能优化之节流

yc8882年前 (2022-12-05)编程技术381

JS 性能优化之节流

1. 节流介绍


节流: n 秒内只运行一次,若在 n 秒内重复触发,只有第一次生效

节流的应用场景:

1. 滚动加载: 监听页面滚动到底部的时候触发
2. 拖拽场景: 固定时间只执行一次,防止高频率的位置变动

2. 滚动加载-节流处理


首先编写监听页面滚动距离的方法,当向下滑动时,可以看到控制台执行了很多次的输出,如果我们要根据页面滑动距离来计算代码逻辑,这样频繁的执行计算会非常损耗系统性能,我们可以使用节流来优化这个问题

  1. <style>
  2. body {
  3. height: 2000px;
  4. background: lightsalmon;
  5. }
  6. </style>
  7. <script>
  8. let count = 1
  9. function scrollFn() {
  10. console.log('监听页面滚动次数: ', count++);
  11. }
  12. document.onscroll = scrollFn
  13. </script>

节流的实现思路:

1. 借助 setTimeout 定时器,控制事件回调是否执行
2. 获取每次事件执行的时间与上一次执行的时间差
3. 判断时间差是否已超过设定的时间间隔,超过时立即执行函数,没有超过时取消后续的定时器任务
4. 最后一次事件的触发,会执行完成

使用节流函数优化后的代码:

  1. // 节流函数
  2. function throttle(fn, time) {
  3. // 上一次的执行时间
  4. let pre = 0
  5. let timeout = null
  6. return function (...args) {
  7. const now = Date.now()
  8. // 时间差超过了设定的时间间隔
  9. if (now - pre > time) {
  10. pre = now
  11. fn.apply(this, args)
  12. } else {
  13. // 没有超过设定的时间间隔,则后续的事件会直接清除
  14. if (timeout) {
  15. clearTimeout(timeout)
  16. timeout = null
  17. }
  18. // 最后一次的事件会触发
  19. timeout = setTimeout(() => {
  20. pre = now
  21. fn.apply(this, args)
  22. }, time);
  23. }
  24. }
  25. }
  26. document.onscroll = throttle(scrollFn, 300)

本站发布的内容若侵犯到您的权益,请邮件联系站长删除,我们将及时处理!


从您进入本站开始,已表示您已同意接受本站【免责声明】中的一切条款!


本站大部分下载资源收集于网络,不保证其完整性以及安全性,请下载后自行研究。


本站资源仅供学习和交流使用,版权归原作者所有,请勿商业运营、违法使用和传播!请在下载后24小时之内自觉删除。


若作商业用途,请购买正版,由于未及时购买和付费发生的侵权行为,使用者自行承担,概与本站无关。


本文链接:https://www.10zhan.com/biancheng/10174.html

标签: JavaScript
分享给朋友:

“JS 性能优化之节流” 的相关文章

【说站】laravel实现自定义404页面并给页面传值

【说站】laravel实现自定义404页面并给页面传值

以 laravel5.8 为例,虽然有自带的404页面,但太简单,我们更希望能自定义404页面,将用户留在站点。实现的方式很简单,将自定义的视图文件命名为 404.blade.php,并放到 reso...

【说站】Thymeleaf报错Error resolving template “XXX”

【说站】Thymeleaf报错Error resolving template “XXX”

修改了一下开源项目的目录结构访问突然报错Error resolving template “XXX”可能原因有如下三种:第一种可能:原因:在使用springboot的过程中,如果使用thymeleaf...

【说站】用一句话就可以去除宝塔面板操作上的二次验证

【说站】用一句话就可以去除宝塔面板操作上的二次验证

用过宝塔的朋友应该都会发现,现在宝塔面板有些鸡肋的功能,删除文件、删除数据库、删除站点等操作都需要做计算题!不仅加了几秒的延时等待,还无法跳过!这时候就会有朋友在想,如何去除宝塔面板的二次验证,此篇文...

【说站】利用Webhook实现Java项目自动化部署

【说站】利用Webhook实现Java项目自动化部署

用webhook就能实现Java项目自动部署,其实原理很简单。费话不多说,直接往下看教程。1. 创建gitee仓库并初始化2. 在linux安装git3. 在宝塔的软件的商店里下载Webhook4....

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

【说站】C#在PDF中添加墨迹注释Ink Annotation的步骤详解

PDF中的墨迹注释(Ink Annotation),表现为徒手涂鸦式的形状;该类型的注释,可任意指定形状顶点的位置及个数,通过指定的顶点,程序将连接各点绘制成平滑的曲线。下面,通过C#程序代码介绍如何...

【说站】Java从resources读取文件内容的方法有哪些

【说站】Java从resources读取文件内容的方法有哪些

本文主要介绍的是java读取resource目录下文件的方法,比如这是你的src目录的结构├── main│ ├── java│ │ └── ...