mousedown 和 mouseup 在触摸设备上触发

rev*_*evy 5 javascript events touch mouseup mousedown

只是好奇mousedownmouseup事件的用途,因为它们也在触摸设备上触发。我认为mousedowntouchstart是互斥的(前者在桌面上工作,后者在触摸设备上工作),并且mouseuptouchend相同,但情况似乎并非如此。一次完整的触摸事件会触发上述所有事件:在 safari 和 chrome 上测试。因此,为了区分单击(鼠标)事件和单击(触摸)事件,我需要使用某种函数来告诉我这是否是触摸设备:

    function isTouchDevice() {
        return 'ontouchstart' in window        // works on most browsers
            || navigator.maxTouchPoints;       // works on IE10/11 and Surface
    }

    myElem.addEventListener("mousedown", () => {
        if (isTouchDevice()) return;
        // do something
    }, false);

    myElem.addEventListener("mouseup", () => {
        if (isTouchDevice()) return;
        // do something
    }, false);

    myElem.addEventListener("touchstart", () => {
        // do something
    }, false);

    myElem.addEventListener("touchend", () => {
        // do something
    }, false);
Run Code Online (Sandbox Code Playgroud)

我是否真的需要检查设备是否为触摸设备以区分鼠标单击和触摸单击?

Dev*_*lds 3

不,您不会也不应该尝试测试设备是否是触摸屏。如果您希望阻止其他事件触发,可以使用 PreventDefault 方法。

myElem.addEventListener("touchstart", (event) => {
   event.preventDefault(); 
   // do something
}, false);
Run Code Online (Sandbox Code Playgroud)

如果您想了解更深入的信息,您应该阅读这篇文章:触摸和鼠标