Javascript 在Firefox41中获取鼠标坐标

Javascript 在Firefox41中获取鼠标坐标,javascript,jquery,firefox,drag-and-drop,mouse-coordinates,Javascript,Jquery,Firefox,Drag And Drop,Mouse Coordinates,我正在尝试根据鼠标坐标拖放一个元素。它在chrome和IE中运行良好,但在firefox中不起作用 以下是我尝试过的: function createShape(event) { var stageContainer = $(".mainArea"); var stageOffset = stageContainer.offset(); clientX = event.clientX; clientY = event.clientY; offsetX =

我正在尝试根据鼠标坐标拖放一个元素。它在chrome和IE中运行良好,但在firefox中不起作用

以下是我尝试过的:

function createShape(event)
{
    var stageContainer = $(".mainArea");
    var stageOffset = stageContainer.offset();
    clientX = event.clientX;
    clientY = event.clientY;
    offsetX = stageOffset.left;
    offsetY = stageOffset.top;
    x = clientX - offsetX; // works in chrome and IE
    y = clientY - offsetY; // works in chrome and IE

    //Firefox
    var offX = (event.offsetX || event.pageX - $(event.target).offset().left);
    var offY = (event.offsetY || event.pageY - $(event.target).offset().top);
    layerX = event.layerX;
    layerY = event.layerX;
    screenX = event.screenX;
    screenY = event.screenY;
    pageX = event.pageX;
    pageY = event.pageY;
    e = jQuery.event.fix(event);
    var target = event.target || event.srcElement;

    //Right now this is working but x and y are not exactly correct
    x = screenX + offsetX
    y = screenY + offsetY
在firefox中不起作用

ClientXY return 0,0
LayerXY return largest number like 173839,173839
pageX and pageY returns 0,0
element.offset().left returns 70 always
element.offset().top returns 63 always

createRect(x, y); // creating element on dragend with x and y coordinates on dragend
}


如何获取拖动结束鼠标坐标?

遗憾的是,Firefox没有填充
pageX
pageY
事件的属性。相关网站自2009年开始开放,看起来不会很快得到修复。常见的解决方案是在父元素上设置事件(尽管这样很难检测正在拖动的元素)或检测正在拖动的元素的位置。

我认为您在链接中提供的解决方案在最新的Firefox中不起作用