Mousemove 事件未在页面元素或文档上触发

Mousemove event not firing on page element or document

我正在尝试使用 js 滑块 slick,但是当我在我的网站上包含滑块代码时,默认的 'draggable' 选项不起作用。 更具体地说,我无法在幻灯片 div 或我网页中的文档 (Chrome) 上捕获任何 mousemove 事件。

当运行本地代码时我观察'mouseup'、'mousemove'和'mouseup'事件没有问题,但是当我将滑块代码放入网页时我只能观察到 'mouseup' 和 'mousedown' 事件。

下面是有效的本地代码。如果你 运行 它,它将记录滑块内的 mousedown、mousemove 和 mouseup 事件 div。

当我将相同的代码移动到网站时,我无法观察到来自滑块 div 或文档的任何 mousemove 事件。是否已经有一些 js 运行ning 可以完全阻止页面触发 mousemove 事件?

<html>
  <head>
      <title>My Now Amazing Webpage</title>

      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.6.0/slick.css"/>
      <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.6.0/slick-theme.css"/>
      <script src="http://code.jquery.com/jquery-1.7.2.min.js"></script>
      <script src="https://cdnjs.cloudflare.com/ajax/libs/slick-carousel/1.6.0/slick.js"></script>
  </head>
  <body>

  <style>

    #container {
      width: 450px;
      height: 300px;
      margin: 0 auto;
      border: 2px solid black;
    }

  </style>

  <div id="container">
    <div class="your-class">
      <div><img src="http://lorempixel.com/300/300" /></div>
      <div><img src="http://lorempixel.com/300/300" /></div>
      <div><img src="http://lorempixel.com/300/300" /></div>
    </div>
  </div>



  <script type="text/javascript">
    $(document).ready(function(){

        $('.your-class').slick();

        $('.slick-slide').on('mousemove', function(e){
          console.log("mousemove");
        });

        $('.slick-slide').on('mousedown', function(e){
          console.log("mousedown");
        });

        $('.slick-slide').on('mouseup', function(e){
          console.log("mouseup");
        });
    });
  </script>

  </body>
</html>

您的本地代码工作正常。按文档抓取事件

$(document).on('mousemove', '.slick-slide', function(){ console.log('mousemove'); });

在网站上查看。

问题出在那个特定的 chrome 选项卡上。我不知道为什么我遇到了问题,但刷新它并没有改变任何东西——但是当我以隐身 window 和新的 chrome window 加载网站时它修复了它。

选项卡之间唯一不同的是,我遇到问题的选项卡打开的时间要长得多(约 3-4 小时)。我不知道为什么这会影响任何事情,但如果有人有任何想法,我很想听听他们的想法。

不确定这是否回答了您的具体问题,但这可能对出现在这里的其他人有所帮助。

如果您正在使用 Chrome 开发工具进行测试(例如)并且您有一个设备配置文件处于活动状态,那么 Chrome 将模拟触摸交互并且不会发送 mousemove 事件(就像这种情况一样) phone/tablet 如果用户的手指没有触摸屏幕,浏览器无法判断何时。

如果您将设备类型从(例如)"Desktop (touch)" 更改为 "Desktop",您将保持所需的屏幕大小,但会恢复鼠标事件。

大多数经历过这种情况的开发者都打开了他们的开发者控制台,在 Chrome 这通常会将您的输入更改为触摸模式,其中没有桌面上的恒定光标。

要么使您的代码具有不同的触摸输入行为以获得所需的结果,要么您可以通过更改随附屏幕截图中显示的选项将设备类型添加到您的开发控制台会话。