javascript函数的throttle和debounce
throttle
鼠标移动,mousemove 事件
DOM 元素动态定位,window对象的resize和scroll 事件
debounce
文本输入keydown 事件,keyup 事件,例如做autocomplete
/*
* 频率控制 返回函数连续调用时,fn 执行频率限定为每多少时间执行一次
* @param fn {function} 需要调用的函数
* @param delay {number} 延迟时间,单位毫秒
* @param immediate {bool} 给 immediate参数传递false 绑定的函数先执行,而不是delay后后执行。
* @return {function}实际调用函数
*/
var throttle = function (fn,delay, immediate, debounce) {
var curr = +new Date(),//当前事件
last_call = 0,
last_exec = 0,
timer = null,
diff, //时间差
context,//上下文
args,
exec = function () {
last_exec = curr;
fn.apply(context, args);
};
return function () {
curr= +new Date();
context = this,
args = arguments,
diff = curr - (debounce ? last_call : last_exec) - delay;
clearTimeout(timer);
if (debounce) {
if (immediate) {
timer = setTimeout(exec, delay);
} else if (diff >= 0) {
exec();
}
} else {
if (diff >= 0) {
exec();
} else if (immediate) {
timer = setTimeout(exec, -diff);
}
}
last_call = curr;
}
};
/*
* 空闲控制 返回函数连续调用时,空闲时间必须大于或等于 delay,fn 才会执行
* @param fn {function} 要调用的函数
* @param delay {number} 空闲时间
* @param immediate {bool} 给 immediate参数传递false 绑定的函数先执行,而不是delay后后执行。
* @return {function}实际调用函数
*/
var debounce = function (fn, delay, immediate) {
return throttle(fn, delay, immediate, true);
};
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:愚人码头 来源: WEB前端开发
- 标签: debounce throttle
- 发布时间:2013-07-08 22:43:51
-
[567] WordPress插件开发 -- 在插件使用 -
[63] IOS安全–浅谈关于IOS加固的几种方法 -
[43] cookie窃取和session劫持 -
[43] 浏览器的工作原理:新式网络浏览器幕后揭秘 -
[42] 浅谈MySQL索引背后的数据结构及算法 -
[42] mysql查询中利用索引的机制 -
[40] 到底什么是MVC? -
[40] Hacker News 排名算法工作原理 -
[39] 推荐一些socket工具,TCP、UDP调试 -
[38] 如何拿下简短的域名