V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
qazwsxkevin
V2EX  ›  JavaScript

想在页面上增加跟随鼠标的十字瞄准线, X 线偏移了,不得其解。。。

  •  
  •   qazwsxkevin · 327 天前 · 1316 次点击
    这是一个创建于 327 天前的主题,其中的信息可能已经有所发展或是发生改变。
        var ox = document.createElement('div');
        var oy = document.createElement('div');
        ox.style.width = '100%';
        ox.style.height = '1px';
        ox.style.backgroundColor = '#FF0000';
        ox.style.position = 'fixed';
        ox.style.left = 0;
        document.body.appendChild(ox);
        oy.style.height = '100%';
        oy.style.width = '1px';
        oy.style.backgroundColor = '#FF0000';
        oy.style.position = 'fixed';
        oy.style.top = 0;
        document.body.appendChild(oy);
        document.onmousemove = function (e) {
            //写法一
            var e = e || event;
            var x = e.pageX;
            var y = e.pageY;
    
            //写法二
            // var e = e || window.event;  //event 的兼容写法
            // var x = e.pageX || e.clientX + scroll().left;  //获取 pageX 的兼容写法
            // var y = e.pageY || e.clientY + scroll().top;
    
            ox.style.top = y + 'px';
            oy.style.left = x + 'px';
        };
    
        //写法二要用到的函数
        function scroll() {
            return {
                "top": window.pageYOffset || document.body.scrollTop || document.documentElement.scrollTop,
                "left": window.pageXOffset || document.body.scrollLeft || document.documentElement.scrollLeft
            }
        }
    

    Y 线是正常跟随鼠标的,X 轴向下偏移了半个屏幕,请教大家问题所在?
    目前只试过 IE 和 Firefox,应该不是兼容问题? 只想在 Firefox 上能跑就可以了。。。

    5 条回复    2021-01-16 11:38:34 +08:00
    IsaacYoung
        1
    IsaacYoung  
       327 天前
    https://developer.mozilla.org/zh-CN/docs/Web/API/MouseEvent/pageX

    pageX 是一个由 MouseEvent 接口返回的相对于整个文档的 x (水平)坐标以像素为单位的只读属性。

    这个属性将基于文档的边缘,考虑任何页面的水平方向上的滚动。举个例子,如果页面向右滚动 200px 并出现了滚动条,这部分在窗口之外,然后鼠标点击距离窗口左边 100px 的位置,pageX 所返回的值将是 300 。
    xiaoming1992
        2
    xiaoming1992  
       327 天前
    你可以直接更换鼠标样式啊,不是更轻量吗
    qazwsxkevin
        3
    qazwsxkevin  
    OP
       327 天前
    @IsaacYoung 明白了,感谢,修正过来了

    @xiaoming1992 表的纵横比较广阔( 64X128 ),第一列是序号,第一行是标题栏,没有十字线,会眼花的。

    本来还想着落到表格的格子上,对应 X,Y 的序号和标题栏高亮的,结果看起来,还是十字线比较靠谱。
    MENGKE
        5
    MENGKE  
       326 天前
    应该为 clientX 和 clientY
    关于   ·   帮助文档   ·   API   ·   FAQ   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   1893 人在线   最高记录 5497   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 20ms · UTC 16:37 · PVG 00:37 · LAX 08:37 · JFK 11:37
    ♥ Do have faith in what you're doing.