Introduction to scroll wheel events

Source: Internet
Author: User

The current web design is becoming more and more advanced, and the effect is becoming increasingly cool. Some browser's default things have been abandoned and replaced by various cool simulation components. As you said beforeParallax scroll, It seems like a variety of small freshSimulate a scroll bar, All have common events:Scroll wheel event.

As you know, the jquery framework does not support wheel scroll events with the mouse by default. To implement scroll events between different browsers, let's not talk about this JS component: jquery. mousewheel. js.


Do not say anything. first go to the source code:

/*! Copyright (c) 2013 Brandon Aaron (http://brandon.aaron.sh) * Licensed under the MIT License (LICENSE.txt). * * Version: 3.1.11 * * Requires: jQuery 1.2.2+ */(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 {        // 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.11',        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 $parent = $(elem)['offsetParent' in $.fn ? 'offsetParent' : 'parent']();            if (!$parent.length) {                $parent = $('body');            }            return parseInt($parent.css('fontSize'), 10);        },        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;    }}));


The two main functions in the JS plug-in are mousewheel and unmousewheel.

There are also a variety of calling methods,

For example, you can:

$('.demo').mousewheel(function(){//to do something});  $('.demo').bind('mousewheel', function(){//to do something});

The following describes its parameters.

In addition to the first parameter event, the parameter of the mousewheel event also receives the second parameter delta. The Delta parameter can be used to obtain the direction and speed of the scroll wheel. If the Delta value is negative, the scroll wheel is scroll down, and the positive is upward.


For example:

VaR evaluate ('height', Gao); $ ('. mod-step '). BIND ('mousewheel ', function (event, Delta) {If (yundong = true) {yundong = false; var Index = parseint ($ (this ). index ('. mod-step') + 1; H = Gao * index; If (delta <0) {// What can I do if I scroll down? // To Do Something} else {// What can I do if I scroll up? // To Do Something}


PS: Let's see how to call the parameters. The details of other codes can be ignored.

Next, let's take a look at the different values returned by different browsers.

First look at Google's: When scrolling down,



And then Firefox. When you scroll down,



And then for ie11, scroll down:



And then ie9, scroll down:




The following is IE8. Scroll down:



Summary: The values returned by various browsers are basically different. Therefore, it is still not scientific to use a specific number, but it is reliable to use a number greater than 0.

If you are interested in the difference, go to Zhang xinxu's blog. Link: http://www.zhangxinxu.com/wordpress/2013/04/js-mousewheel-dommousescroll-event/


I will not talk much about the use of scroll wheel events. I will provide several demos for you to see. It is really easy to use.

Http://joelb.me/scrollpath/

Http://manos.malihu.gr/jquery-custom-content-scroller/

Http://noraesae.github.io/perfect-scrollbar/


Conclusion: although it is not a big plug-in, it fills in jquery's defect that there is no scroll event and is simple and practical.



Author: alone
Antroduction: Senior front-end development engineer
Sign: there is no failure in life, only success in life.

Introduction to scroll wheel events

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.