使用方法
(function ($) {
"use strict";
// vars
var timeout;
var firstEvent = true;
var settings = {};
var namespace = '.jq-inactivity';
var events = {
mouseEvents: "mousemove mousedown mousewheel wheel DOMMouseScroll MSPointerDown MSPointerMove",
keyboardEvents: "keypress keydown keyup",
touchEvents: "touchstart touchmove touchend"
};
$.fn.inactivity = function (opts) {
var $el = $(this);
var namespacedEvents = {
mouseEvents: addNamespace(events.mouseEvents),
keyboardEvents: addNamespace(events.keyboardEvents),
touchEvents: addNamespace(events.touchEvents)
};
// defaults
settings = $.extend({
timeout: 3000,
mouse: true,
keyboard: true,
touch: true,
customEvents: "",
triggerAll: false
}, opts);
clear($el);
// when "destroy" requested by opts
if (opts === "destroy") {
return;
}
// set event listeners
if (settings.mouse) {
$el.on(namespacedEvents.mouseEvents, onActivity);
}
if (settings.keyboard) {
$el.on(namespacedEvents.keyboardEvents, onActivity);
}
if (settings.touch) {
$el.on(namespacedEvents.touchEvents, onActivity);
}
if (settings.customEvents !== '') {
$el.on(settings.customEvents, onActivity);
}
function onActivity() {
window.clearTimeout(timeout);
timeout = window.setTimeout(onInactivity, settings.timeout);
if (settings.triggerAll || firstEvent) {
$el.trigger("activity");
}
if (firstEvent) {
firstEvent = false;
}
}
function onInactivity() {
firstEvent = true;
$el.trigger("inactivity");
}
function addNamespace(eventString) {
var events = eventString.split(' ');
var namespacedEvents = events.map(function (event) {
return event + namespace;
});
return namespacedEvents.join(' ');
}
// clear all event listeners & reset plugin
function clear($el) {
$el.off(namespacedEvents.mouseEvents);
$el.off(namespacedEvents.keyboardEvents);
$el.off(namespacedEvents.touchEvents);
if (settings.customEvents !== '') {
$el.off(settings.customEvents);
}
window.clearTimeout(timeout);
firstEvent = true;
}
};
})(jQuery);
站长提示:
1. 苦力吧素材官方QQ群:
950875342
2. 平台上所有素材资源,需注册登录会员方能正常下载。
3. 会员用户积极反馈网站、素材资源BUG或错误问题,每次奖励
2K币。
4. PHP源码类素材,如需协助安装调试,或你有二次开发需求,可联系苦力吧客服。
5. 付费素材资源,需充值后方能下载,如有任何疑问可直接联系苦力吧客服