首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >JS使用mousemove或touchmove

JS使用mousemove或touchmove
EN

Stack Overflow用户
提问于 2014-03-15 12:34:57
回答 1查看 836关注 0票数 1

我想知道,根据应用程序使用的设备,如何使用mousemove或touchmove。我想让触控设备听触移动,而桌面设备使用mousemove代替。我还想使用移动设备上似乎缺少的offsetX和offsetY =/

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2014-03-15 12:38:07

您可以将事件包装在一个对象中,并根据is_touch_supported设置它们:

代码语言:javascript
复制
var body = document.querySelector('body'),
    is_touch_supported = ('ontouchstart' in window) ? true : false,
    EVENTS = {
      POINTER_DOWN : is_touch_supported ? 'touchstart' : 'mousedown',
      POINTER_UP   : is_touch_supported ? 'touchend'   : 'mouseup',
      POINTER_MOVE : is_touch_supported ? 'touchmove'  : 'mousemove'
    };

现在,您可以使用这样的事件:

代码语言:javascript
复制
body.addEventListener(EVENTS.POINTER_MOVE, function (e) {
  e.preventDefault();

  // normalize event so you can use e.offset X/Y
  if(is_touch_supported){
    e = e.changedTouches[0];
    e.offsetX = e.pageX - e.target.offsetLeft;
    e.offsetY = e.pageY - e.target.offsetTop;
  }

  // ...
});
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22423869

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档