浏览器touch兼容方法

找了好久,解决移动端touch事件在pc端出现的问题


(function(window) {
    /**
     * Do not use thumbs.js on touch-enabled devices
     * 
     * Thanks to Jesse MacFadyen (purplecabbage):
     * https://gist.github.com/850593#gistcomment-22484
     */
    try {
        document.createEvent('TouchEvent');
        return;
    } catch(e) {}

    /**
     * Map touch events to mouse events
     */
    var eventMap = {
        'mousedown': 'touchstart',
        'mouseup':   'touchend',
        'mousemove': 'touchmove'
    };

    /**
     * Initialize thumbs.js
     */
    var initialize = function() {
        /* Bind touch events to mouse events */
        for (var key in eventMap) {
            /**
             * Fire a touch event.
             *
             * Monitor mouse events and fire a touch event on the
             * object broadcasting the mouse event. This approach
             * likely has poorer performance than hijacking addEventListener
             * but it is a little more browser friendly.
             */
            document.body.addEventListener(key, function(e) {
                /*
                 * Supports:
                 *   - addEventListener
                 *   - setAttribute
                 */
                var event = createTouchEvent(eventMap[e.type], e);
                e.target.dispatchEvent(event);

                /*
                 * Supports:
                 *   - element.ontouchstart
                 */
                var fn = e.target['on' + eventMap[e.type]];
                if (typeof fn === 'function') fn(e);
            }, false);
        }
    };

    /**
     * Utility function to create a touch event.
     *
     * @param  name  {String} of the event
     * @return event {Object}
     */
    var createTouchEvent = function(name, e) {
        var event = document.createEvent('MouseEvents');
        event.initMouseEvent(
            name,
            e.bubbles,
            e.cancelable,
            e.view,
            e.detail,
            e.screenX,
            e.screenY,
            e.clientX,
            e.clientY,
            e.ctrlKey,
            e.altKey,
            e.shiftKey,
            e.metaKey,
            e.button,
            e.relatedTarget
        );
        return event;
    };

    /**
     * Initialize thumbs.js
     *
     * Initializes on document-load and dynamic-loading.
     */
    if (document.readyState === 'complete' || document.readyState === 'loaded') {
        initialize();
    } else {
        window.addEventListener('load', initialize, false);
    }
})(window);
 windows下安装mongoDB
rem设置方法 
上一篇:windows下安装mongoDB
下一篇:rem设置方法
评论

如果我的文章对你有帮助,或许可以打赏一下呀!

支付宝
微信
QQ