滚轮改值

复制代码
<!DOCTYPE html>

<style>
    span {font:14px/20px 微软雅黑;}
    #counter {
        width:50px;height:20px;
        border:1px solid #CCC;
        background:#F9F9F9;
        font:14px/20px Consolas;
        text-align:center;
        margin:10px;
    }
</style>
<span>使用鼠标滚轮调整数值大小</span><br/>
<div id="counter">0</div>
<script>

    //禁止页面滚轮
    function disabledMouseWheel() {

        if (document.addEventListener) {
            document.addEventListener('DOMMouseScroll', scrollFunc, false);
        }//W3C
        window.onmousewheel = document.onmousewheel = scrollFunc;//IE/Opera/Chrome
    }
    function scrollFunc(evt) {
        return false;
    }
    window.onload=disabledMouseWheel;


    //判断浏览器
    var isIE=navigator.userAgent.match(/MSIE (\d)/i);
    isIE=isIE?isIE[1]:undefined;
    var isFF=/FireFox/i.test(navigator.userAgent);
    //获取元素
    var counter=document.getElementById("counter");
    //鼠标滚轮事件
    if(isIE<9) //传统浏览器使用MouseWheel事件
        counter.attachEvent("onmousewheel",function(){
            //计算鼠标滚轮滚动的距离
            //一格3行,每行40像素,所以除以120
            var v=event.wheelDelta/120;
            counter.innerHTML=counter.innerHTML*1+v;
            //阻止浏览器默认方法
            return false;
        });
    else if(!isFF) //除火狐外的现代浏览器也使用MouseWheel事件
        counter.addEventListener("mousewheel",function(e){
            //计算鼠标滚轮滚动的距离
            var v=e.wheelDelta/120;
            counter.innerHTML=counter.innerHTML*1+v;
            //阻止浏览器默认方法
            e.preventDefault();
        },false);
    else //奇葩的火狐使用DOMMouseScroll事件
        counter.addEventListener("DOMMouseScroll",function(e){
            //计算鼠标滚轮滚动的距离
            //一格是3行,但是要注意,这里和像素不同的是它是负值
            var v=-e.detail/3;
            counter.innerHTML=counter.innerHTML*1+v;
            //阻止浏览器默认方法
            e.preventDefault();
        },false);
</script>
复制代码

 

posted @   终究是乌云遮了天  阅读(193)  评论(0编辑  收藏  举报
编辑推荐:
· 从二进制到误差:逐行拆解C语言浮点运算中的4008175468544之谜
· .NET制作智能桌面机器人:结合BotSharp智能体框架开发语音交互
· 软件产品开发中常见的10个问题及处理方法
· .NET 原生驾驭 AI 新基建实战系列:向量数据库的应用与畅想
· 从问题排查到源码分析:ActiveMQ消费端频繁日志刷屏的秘密
阅读排行:
· 《HelloGitHub》第 108 期
· Windows桌面应用自动更新解决方案SharpUpdater5发布
· 我的家庭实验室服务器集群硬件清单
· C# 13 中的新增功能实操
· Supergateway:MCP服务器的远程调试与集成工具
点击右上角即可分享
微信分享提示