无法在被动事件侦听器 jQuery Mobile 中阻止默认

mKa*_*gac 1 mobile jquery jquery-mobile

我使用 jQuery Mobile v1.5.0 使菜单在滑动时打开,一切正常,但此错误始终存在,我尝试添加 addEventListener 示例:

// open menu on swipe to right
$(document).on('swiperight', function(e) {
    document.addEventListener("swiperight", e.preventDefault(), {passive: false} );
    e.preventDefault()
    $('.menu').addClass('active');
});
Run Code Online (Sandbox Code Playgroud)

但错误仍然存​​在

Unable to preventDefault inside passive event listener due to target being treated as passive.
Run Code Online (Sandbox Code Playgroud)

代码:

// open menu on swipe to right
$(document).on('swiperight', function(e) {
    e.preventDefault()
    $('.menu').addClass('active');
});
Run Code Online (Sandbox Code Playgroud)

Luc*_*tos 6

仅供参考:就我而言(使用 Owl Carousel),对我的修复是纯 css:

.owl-carousel {
    touch-action: manipulation; 
}
Run Code Online (Sandbox Code Playgroud)


deb*_*ker 5

无需添加另一个eventListener. 可以使用 CSS 解决此错误。添加touch-action: none;到您正在滑动的容器中。

这是一个使用外部 JQM 面板作为全局导航菜单的演示

$(document)
  .on('swiperight', '#page-acura, #page-audi, #page-bmw', function(e) {
    $("#panel").panel("open");
  })
  .ready(function() {
    $("#panel").panel({theme: "a", display: "overlay"}).enhanceWithin();
  });
Run Code Online (Sandbox Code Playgroud)
.ui-page,
.ui-panel,
.ui-panel-wrapper,
.ui-panel-dismiss {
  touch-action: none;
}

h1, h2, h3, h4, h5, h6, p {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
Run Code Online (Sandbox Code Playgroud)
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>JQM 1.5.0 RC1 Panel Menu</title>
    <meta name="HandheldFriendly" content="True">
    <meta name="MobileOptimized" content="320">
    <meta name="viewport" content="user-scalable=no, initial-scale=1.0001, maximum-scale=1.0001, width=device-width, minimal-ui shrink-to-fit=no">
    <meta http-equiv="cleartype" content="on">
    <link rel="stylesheet" href="https://code.jquery.com/mobile/1.5.0-rc1/jquery.mobile-1.5.0-rc1.min.css" />
    <script src="https://code.jquery.com/jquery-3.4.0.min.js"></script>
    <script src="https://code.jquery.com/mobile/1.5.0-rc1/jquery.mobile-1.5.0-rc1.min.js"></script>
  </head>
  <body>
    <div data-role="page" id="page-acura">
      <div class="ui-toolbar-header ui-body-a">
        <h2 class="ui-toolbar-title">Acura</h2>
      </div>
      <div role="main" class="ui-content">
        <p>Acura content goes here.</p>
      </div>
      <div class="ui-toolbar-footer ui-toolbar-footer-fixed ui-body-a">
        <h2 class="ui-toolbar-title">Footer</h2>
      </div>
    </div>
    <div data-role="page" id="page-audi">
      <div class="ui-toolbar-header ui-body-a">
        <h2 class="ui-toolbar-title">Audi</h2>
      </div>
      <div role="main" class="ui-content">
        <p>Audi content goes here.</p>
      </div>
      <div class="ui-toolbar-footer ui-toolbar-footer-fixed ui-body-a">
        <h2 class="ui-toolbar-title">Footer</h2>
      </div>
    </div>
    <div data-role="page" id="page-bmw">
      <div class="ui-toolbar-header ui-body-a">
        <h2 class="ui-toolbar-title">BMW</h2>
      </div>
      <div role="main" class="ui-content">
        <p>BMW content goes here.</p>
      </div>
      <div class="ui-toolbar-footer ui-toolbar-footer-fixed ui-body-a">
        <h2 class="ui-toolbar-title">Footer</h2>
      </div>
    </div>
    <div data-role="panel" id="panel">
      <ul data-role="listview" data-icon="false" data-inset="true">
        <li><a href="#page-acura">Acura</a></li>
        <li><a href="#page-audi">Audi</a></li>
        <li><a href="#page-bmw">BMW</a></li>
      </ul>
    </div>
  </body>
</html>
Run Code Online (Sandbox Code Playgroud)