123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240 |
- /*!
- * jQuery Mousewheel 3.1.13
- *
- * Copyright jQuery Foundation and other contributors
- * Released under the MIT license
- * http://jquery.org/license
- */
- (function (factory) {
- if (typeof define === 'function' && define.amd) {
- // AMD. Register as an anonymous module.
- define(['jquery'], factory);
- } else if (typeof exports === 'object') {
- // Node/CommonJS style for Browserify
- module.exports = factory;
- } else if (window.layui && layui.define) { // layui加载
- layui.define('jquery', function (exports) {
- var $ = layui.jquery;
- exports('mousewheel', factory($));
- });
- } else {
- // Browser globals
- factory(jQuery);
- }
- }(function ($) {
- var toFix = ['wheel', 'mousewheel', 'DOMMouseScroll', 'MozMousePixelScroll'],
- toBind = ('onwheel' in document || document.documentMode >= 9) ?
- ['wheel'] : ['mousewheel', 'DomMouseScroll', 'MozMousePixelScroll'],
- slice = Array.prototype.slice,
- nullLowestDeltaTimeout, lowestDelta;
- if ($.event.fixHooks) {
- for (var i = toFix.length; i;) {
- $.event.fixHooks[toFix[--i]] = $.event.mouseHooks;
- }
- }
- var special = $.event.special.mousewheel = {
- version: '3.1.12',
- setup: function () {
- if (this.addEventListener) {
- for (var i = toBind.length; i;) {
- this.addEventListener(toBind[--i], handler, false);
- }
- } else {
- this.onmousewheel = handler;
- }
- // Store the line height and page height for this particular element
- $.data(this, 'mousewheel-line-height', special.getLineHeight(this));
- $.data(this, 'mousewheel-page-height', special.getPageHeight(this));
- },
- teardown: function () {
- if (this.removeEventListener) {
- for (var i = toBind.length; i;) {
- this.removeEventListener(toBind[--i], handler, false);
- }
- } else {
- this.onmousewheel = null;
- }
- // Clean up the data we added to the element
- $.removeData(this, 'mousewheel-line-height');
- $.removeData(this, 'mousewheel-page-height');
- },
- getLineHeight: function (elem) {
- var $elem = $(elem),
- $parent = $elem['offsetParent' in $.fn ? 'offsetParent' : 'parent']();
- if (!$parent.length) {
- $parent = $('body');
- }
- return parseInt($parent.css('fontSize'), 10) || parseInt($elem.css('fontSize'), 10) || 16;
- },
- getPageHeight: function (elem) {
- return $(elem).height();
- },
- settings: {
- adjustOldDeltas: true, // see shouldAdjustOldDeltas() below
- normalizeOffset: true // calls getBoundingClientRect for each event
- }
- };
- $.fn.extend({
- mousewheel: function (fn) {
- return fn ? this.bind('mousewheel', fn) : this.trigger('mousewheel');
- },
- unmousewheel: function (fn) {
- return this.unbind('mousewheel', fn);
- }
- });
- function handler(event) {
- var orgEvent = event || window.event,
- args = slice.call(arguments, 1),
- delta = 0,
- deltaX = 0,
- deltaY = 0,
- absDelta = 0,
- offsetX = 0,
- offsetY = 0;
- event = $.event.fix(orgEvent);
- event.type = 'mousewheel';
- // Old school scrollwheel delta
- if ('detail' in orgEvent) {
- deltaY = orgEvent.detail * -1;
- }
- if ('wheelDelta' in orgEvent) {
- deltaY = orgEvent.wheelDelta;
- }
- if ('wheelDeltaY' in orgEvent) {
- deltaY = orgEvent.wheelDeltaY;
- }
- if ('wheelDeltaX' in orgEvent) {
- deltaX = orgEvent.wheelDeltaX * -1;
- }
- // Firefox < 17 horizontal scrolling related to DOMMouseScroll event
- if ('axis' in orgEvent && orgEvent.axis === orgEvent.HORIZONTAL_AXIS) {
- deltaX = deltaY * -1;
- deltaY = 0;
- }
- // Set delta to be deltaY or deltaX if deltaY is 0 for backwards compatabilitiy
- delta = deltaY === 0 ? deltaX : deltaY;
- // New school wheel delta (wheel event)
- if ('deltaY' in orgEvent) {
- deltaY = orgEvent.deltaY * -1;
- delta = deltaY;
- }
- if ('deltaX' in orgEvent) {
- deltaX = orgEvent.deltaX;
- if (deltaY === 0) {
- delta = deltaX * -1;
- }
- }
- // No change actually happened, no reason to go any further
- if (deltaY === 0 && deltaX === 0) {
- return;
- }
- // Need to convert lines and pages to pixels if we aren't already in pixels
- // There are three delta modes:
- // * deltaMode 0 is by pixels, nothing to do
- // * deltaMode 1 is by lines
- // * deltaMode 2 is by pages
- if (orgEvent.deltaMode === 1) {
- var lineHeight = $.data(this, 'mousewheel-line-height');
- delta *= lineHeight;
- deltaY *= lineHeight;
- deltaX *= lineHeight;
- } else if (orgEvent.deltaMode === 2) {
- var pageHeight = $.data(this, 'mousewheel-page-height');
- delta *= pageHeight;
- deltaY *= pageHeight;
- deltaX *= pageHeight;
- }
- // Store lowest absolute delta to normalize the delta values
- absDelta = Math.max(Math.abs(deltaY), Math.abs(deltaX));
- if (!lowestDelta || absDelta < lowestDelta) {
- lowestDelta = absDelta;
- // Adjust older deltas if necessary
- if (shouldAdjustOldDeltas(orgEvent, absDelta)) {
- lowestDelta /= 40;
- }
- }
- // Adjust older deltas if necessary
- if (shouldAdjustOldDeltas(orgEvent, absDelta)) {
- // Divide all the things by 40!
- delta /= 40;
- deltaX /= 40;
- deltaY /= 40;
- }
- // Get a whole, normalized value for the deltas
- delta = Math[delta >= 1 ? 'floor' : 'ceil'](delta / lowestDelta);
- deltaX = Math[deltaX >= 1 ? 'floor' : 'ceil'](deltaX / lowestDelta);
- deltaY = Math[deltaY >= 1 ? 'floor' : 'ceil'](deltaY / lowestDelta);
- // Normalise offsetX and offsetY properties
- if (special.settings.normalizeOffset && this.getBoundingClientRect) {
- var boundingRect = this.getBoundingClientRect();
- offsetX = event.clientX - boundingRect.left;
- offsetY = event.clientY - boundingRect.top;
- }
- // Add information to the event object
- event.deltaX = deltaX;
- event.deltaY = deltaY;
- event.deltaFactor = lowestDelta;
- event.offsetX = offsetX;
- event.offsetY = offsetY;
- // Go ahead and set deltaMode to 0 since we converted to pixels
- // Although this is a little odd since we overwrite the deltaX/Y
- // properties with normalized deltas.
- event.deltaMode = 0;
- // Add event and delta to the front of the arguments
- args.unshift(event, delta, deltaX, deltaY);
- // Clearout lowestDelta after sometime to better
- // handle multiple device types that give different
- // a different lowestDelta
- // Ex: trackpad = 3 and mouse wheel = 120
- if (nullLowestDeltaTimeout) {
- clearTimeout(nullLowestDeltaTimeout);
- }
- nullLowestDeltaTimeout = setTimeout(nullLowestDelta, 200);
- return ($.event.dispatch || $.event.handle).apply(this, args);
- }
- function nullLowestDelta() {
- lowestDelta = null;
- }
- function shouldAdjustOldDeltas(orgEvent, absDelta) {
- // If this is an older event and the delta is divisable by 120,
- // then we are assuming that the browser is treating this as an
- // older mouse wheel event and that we should divide the deltas
- // by 40 to try and get a more usable deltaFactor.
- // Side note, this actually impacts the reported scroll distance
- // in older browsers and can cause scrolling to be slower than native.
- // Turn this off by setting $.event.special.mousewheel.settings.adjustOldDeltas to false.
- return special.settings.adjustOldDeltas && orgEvent.type === 'mousewheel' && absDelta % 120 === 0;
- }
- }));
|