| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> JavaScript知识库 -> 前端初学者笔记(一)JavaScript的防抖/节流函数 -> 正文阅读 |
|
[JavaScript知识库]前端初学者笔记(一)JavaScript的防抖/节流函数 |
在常见的浏览器网页B/S架构中,用户在网页发送的请求很快就能发送到服务器端。 若用户发送的请求次数过多,后端可能无法快速处理,或某些函数执行次数过多,浏览器可能将面临卡死的状况。因此防抖函数和节流函数应运而生。 防抖函数(debounce) 本质是通过setTimeout()方法延时处理函数的自定义函数:
用例: debounce( submit(), 200 ) 效果:如果短时间内大量触发同一事件,只会执行一次函数。 实现:既然前面提到了计时,实现的关键就在于setTimeout这个函数,由于还需要一个变量来保存计时,考虑维护全局纯净,可以借助闭包来实现。 防抖函数已经处理了某些函数执行次数过多的问题,但并不完美。当用户短时间内大量触发事件时只会等待用户停止触发后的delay毫秒后才会触发一次函数,而若用户有以下需求:在不停执行请求函数时也能不间断的发送一些请求,如在滑动浏览器滚动条时,在控制台打印其位置。 我们知道浏览器滚动条的位置是连续的,若直接打印位置会使执行打印函数次数过多,导致浏览器卡死。而采用防抖函数时,只会当用户松开鼠标停下delay毫秒后才会打印一次滚动条位置,而这并不符合用户需要实时动态地打印滚动条位置的要求。 节流函数(throttle) 可以满足上述要求: (不止一种实现方案,该处只是举例,节流函数甚至可以完全不借助setTimeout,可以把状态位换成时间戳,然后利用时间戳差值是否大于指定间隔时间来做判定。)
?不使用setTimeout的时间戳实现节流函数的方法:
?这是一种类似于控制阀门一样定期开放的函数,当让函数执行一次后,在某个时间段内暂时失效,过了这段时间后才再重新激活。 效果:如果短时间内大量触发同一事件,在函数执行一次之后,该函数在指定的时间期限内不再工作,直至过了这段时间才重新生效。 在上述打印滚动条位置的案例中,将节流函数应用进去:
效果是在用户不停地滑动滚动条时,每隔200毫秒就在控制台打印滚动条的位置,这便符合用户的需求。 总结: 防抖/节流函数在当下的应用有很多,除了上述的案例外,具体的还有如: 防抖:每次resize/scroll触发统计事件、文本输入的验证(连续输入文字发送的AJAX请求只验证一次) 节流:谷歌搜索框/搜索联想、高频点击间断提交,表单重复提交; 等等。 即便在前端有大量框架工具的情况下,我们处理一些问题时也总是绕不开原生的JavaScript脚本, ?因此要掌握牢固的基础知识,在面对问题时积极调动逻辑。 |
|
JavaScript知识库 最新文章 |
ES6的相关知识点 |
react 函数式组件 & react其他一些总结 |
Vue基础超详细 |
前端JS也可以连点成线(Vue中运用 AntVG6) |
Vue事件处理的基本使用 |
Vue后台项目的记录 (一) |
前后端分离vue跨域,devServer配置proxy代理 |
TypeScript |
初识vuex |
vue项目安装包指令收集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/23 4:36:05- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |