You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
67 lines
1.4 KiB
67 lines
1.4 KiB
5 months ago
|
/**
|
||
|
* 节流函数;当被调用 n 毫秒后才会执行,如果在这时间内又被调用则至少每隔 n 秒毫秒调用一次该函数
|
||
|
*
|
||
|
* @param {Function} callback 回调
|
||
|
* @param {Number} wait 多少秒毫
|
||
|
* @param {Object} options 参数{leading: 是否在之前执行, trailing: 是否在之后执行}
|
||
|
* @return {Function}
|
||
|
*/
|
||
|
function throttle (callback, wait, options) {
|
||
|
var args = null
|
||
|
var context = null
|
||
|
var opts = options || {}
|
||
|
var runFlag = false
|
||
|
var timeout = null
|
||
|
var optLeading = 'leading' in opts ? opts.leading : true
|
||
|
var optTrailing = 'trailing' in opts ? opts.trailing : false
|
||
|
|
||
|
var gcFn = function () {
|
||
|
args = null
|
||
|
context = null
|
||
|
}
|
||
|
|
||
|
var runFn = function () {
|
||
|
runFlag = true
|
||
|
callback.apply(context, args)
|
||
|
timeout = setTimeout(endFn, wait)
|
||
|
gcFn()
|
||
|
}
|
||
|
|
||
|
var endFn = function () {
|
||
|
timeout = null
|
||
|
if (!runFlag && optTrailing === true) {
|
||
|
runFn()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
var cancelFn = function () {
|
||
|
var rest = timeout !== null
|
||
|
if (rest) {
|
||
|
clearTimeout(timeout)
|
||
|
}
|
||
|
gcFn()
|
||
|
timeout = null
|
||
|
runFlag = false
|
||
|
return rest
|
||
|
}
|
||
|
|
||
|
var throttled = function () {
|
||
|
args = arguments
|
||
|
context = this
|
||
|
runFlag = false
|
||
|
if (timeout === null) {
|
||
|
if (optLeading === true) {
|
||
|
runFn()
|
||
|
} else if (optTrailing === true) {
|
||
|
timeout = setTimeout(endFn, wait)
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
throttled.cancel = cancelFn
|
||
|
|
||
|
return throttled
|
||
|
}
|
||
|
|
||
|
module.exports = throttle
|