一些用户频繁触发的事件操作,对于dom操作,资源加载等消耗性能的处理可能会导致页面卡顿,这时就需要用到函数节流(throttle)和函数防抖(debounce)
函数防抖
事件被触发n秒之后再执行,如果在这个n秒之内被再次触发,就重新计时
使用场景:
- 做输入框自动补全提示(实时搜索),需要监听用户的输入行为,根据输入内容去请求后端接口,如果不做函数防抖的话,每次触发keyup就要请求一次,非常消耗性能
- 拖拽
实现函数防抖:用setTimeout
function debounce(fn, delay){
var timer;
return function(e){
var that = this;
clearTimeout(timer);
timer = setTimeout(function(){
fn.call(that, e)
}, delay)
}
}
function fn(args){
console.log(args)
}
document.getElementById('debounce').addEventListener("click",function(e){
debounce(click, 500)(e)
})
函数节流
预定一个函数只有在大于等于执行周期时才执行,周期内调用不执行,不管函数触发的多频繁都会保证一个周期执行一次
使用场景:
- 窗口resize
- 页面滚动scroll
实现函数节流:
function throttle(fn, delay){
let prev = 0;
return function(args){
let that = this;
let now = Date.now();
if(now - prev >= delay){
fn.call(that, args);
prev = now;
}
}
}