js的节流与防抖

作者 : 开心源码 本文共659个字,预计阅读时间需要2分钟 发布时间: 2022-05-13 共231人阅读

项目上线后,经常会报出客户一直点击导致连续出发事件引发体验上的问题,尤其是在监听浏览器滚动scroll,页面调整resise的时候,这个时候我们就需要通过节流/防抖来优化这个问题;

防抖:

防抖就是指在某个时间内再次触发事件则会进行重新计时,也就是说一直触发事件则时间在不断重置;举个例子:
function debounce(method, delay){
????var timer = null;
????return function(){
????????var context = this,args = arguments;
????????clearTimeout(timer);
????????timer = setTimeout(function(){
????????????method.apply(context, args);
????????},delay);
????}
}

节流:

所谓节流,就是指在高频触发事件时,只有在大于设定的周期时间内才去触发一次,触发后这个周期时间清零重新开始计算,和防抖的区别就是为了确保在这个周期时间只执行一次;

function throttle(method, delay){
?????var last = 0;
?????return function (){
????????var now = +new Date();
????????if(now – last > delay){
????????????method.apply(this,arguments);
????????????last = now
?????????}
????}
}

说明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » js的节流与防抖

发表回复