javascript – 在与页面上的元素交互时阻止滑动事件

我正在构建一个iPad应用程序,它本质上是一系列幻灯片.

当我读完幻灯片后,我可以滑动到下一张幻灯片*(使用Zepto的滑动),将window.location更改为下一张幻灯片. (滑动事件绑定到window.body,因为它需要在整个页面上工作)…

问题在于:某些幻灯片具有交互式元素,如按钮,可拖动项等.问题是在使用其中一些交互元素时会触发滑动事件.

有没有人知道在这些情况下防止滑动触发的方法?也许设置灵敏度等?

我很难过……

祝福,非常感谢!!

解决方法

Zepto管理触摸事件的方式是将侦听器绑定到document.body上的touchstart,touchend和touchmove事件.然后,它对要发送的事件执行计算,并在接收到touchstart事件的元素上触发事件.然后,此事件通过DOM树冒泡,唤起每个元素的侦听器.

这为我们提供了两种防止滑动事件的方法:

首先,你可以这样做:

$('#my-child-element').bind('touchstart touchend touchup',function(event) {
    event.stopPropagation();
});

当您的子元素收到一个触摸事件时,它将阻止它传播到父元素,最重要的是身体标记.这可以防止Zepto touch处理器执行任何操作,阻止在该元素中操作时发生滑动,点击,singleTap,longTap和doubleTap事件.

由于滑动事件也会冒泡,您还可以阻止这些特定事件冒泡到侦听页面更改滑动的元素:

$('#my-child-element').bind('swipeLeft swipeRight',function(event) {
    event.stopPropagation();
});

这将允许您仍然在子元素内部接收Zepto生成的事件,但不在外部. Zepto tap事件也将适用于您孩子的所有元素.

小提琴:http://jsfiddle.net/bnickel/dUuUd/

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


kindeditor4.x代码高亮功能默认使用的是prettify插件,prettify是Google提供的一款源代码语法高亮着色器,它提供一种简单的形式来着色HTML页面上的程序代码,实现方式如下: 首先在编辑器里面插入javascript代码: 确定后会在编辑器插入这样的代码: <pre
这一篇我将介绍如何让kindeditor4.x整合SyntaxHighlighter代码高亮,因为SyntaxHighlighter的应用非常广泛,所以将kindeditor默认的prettify替换为SyntaxHighlighter代码高亮插件 上一篇“让kindeditor显示高亮代码”中已经
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高
JS对象如何转为json格式字符串
JS怎么获取图片原始宽高
怎么在click事件中调用多个js函数
js如何往数组中添加新元素
js如何拆分字符串
JS怎么对数组内元素进行求和
JS如何判断屏幕大小
js怎么解析json数据
js如何实时获取浏览器窗口大小
原生JS实现别踩白块小游戏(五)
原生JS实现别踩白块小游戏(一)