【兼容】鼠标滚轮方向问题

本文探讨了在JavaScript中如何处理火狐浏览器与Chrome滚动事件的差异,通过示例代码展示了如何根据不同浏览器调整DOMMouseScroll和mousewheel事件的处理方式,确保跨平台的滚动方向识别一致性。
摘要由CSDN通过智能技术生成

鼠标滚动方向一般情况下向上值为正,向下值为负,但在火狐浏览器中相反。考虑处理兼容问题。

兼容问题

<script>
    window.onload = function(){
        var testNode = document.querySelector('#test');

        // 火狐
        if(testNode.addEventListener){
            testNode.addEventListener("DOMMouseScroll",function(ev){
                ev = ev||event;
                /*       
                向下:正
                向上:负
                 */
                console.log(ev.detail)
            })
        }
        // 非火狐浏览器
        testNode.onmousewheel = function(ev){
            ev = ev||event;
            /*
            向下:负
            向上:正 
            */
            console.log(ev.wheelDelta)
        }
    }
</script>

chrome
在这里插入图片描述

firefox
在这里插入图片描述

兼容代码

<script>
    window.onload = function(){
        var testNode = document.querySelector('#test');

        // 火狐
        if(testNode.addEventListener){
            testNode.addEventListener("DOMMouseScroll",fn);
        }
        // !非火狐浏览器
        testNode.onmousewheel = fn;

        function fn(ev){
            ev = ev||event;
            var dir = "";
            if(ev.wheelDelta){
                dir = ev.wheelDelta>0 ? "up":"down";
            }
            if(ev.detail){
                dir = ev.detail<0 ? "up":"down";
            }
            console.log(dir)
        }

    }
</script>

chrome
在这里插入图片描述

firefox
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值