- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不知道这是否可能,但我正在尝试通过 <a>
检测 touchstart标签。触摸时,应防止滚动,但如果手指没有移动就松开,打开新窗口的链接行为应保持不变。我意识到你不能延迟(超时)e.preventDefault()
, 因为尽管没有抛出错误,它也不会工作。
var a = document.querySelector('a');
a.addEventListener("touchstart", handle_touchstart);
function handle_touchstart(e){
e.preventDefault();
//do other stuff
}
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Blanditiis unde, natus iusto, laborum dignissimos praesentium nam animi, ipsa inventore eius nihil! Sit nam voluptate eveniet sunt a tempore iure quibusdam!</p>
<p>Ratione inventore earum, non eveniet omnis incidunt dicta debitis, ipsum suscipit quas tenetur amet provident officiis labore, veritatis commodi consequatur! Ea dolorum, quis rerum minus quasi consequuntur eius odio reiciendis.</p>
<br>
<a href="http://nestordominguez.com" target="_blank">Click here</a>
<br>
<p>Laboriosam dicta officiis amet fuga! Atque officia, cupiditate recusandae vitae laboriosam dolorem tenetur minus. Perspiciatis nesciunt tenetur deserunt placeat similique ipsa reprehenderit! Esse ducimus laboriosam nulla, autem quibusdam corporis totam.</p>
<p>Aliquam dignissimos ex non magnam, rerum odio voluptates ducimus aspernatur. Dolorem quas, molestias dicta recusandae dolorum earum adipisci modi nemo alias accusantium eaque. At eos, dolorum et culpa quaerat recusandae!</p>
<p>Veniam tempora numquam aliquam perferendis, dolor voluptatem at, eligendi explicabo sunt minima nam debitis possimus nemo esse doloribus itaque consectetur odio rerum dolorum quasi facere saepe quidem. Laborum, cum, asperiores?</p>
<p>Magni, delectus. Illo sed blanditiis quae pariatur amet ratione quis perspiciatis error veritatis non laborum quibusdam ea, suscipit sequi esse velit doloribus ducimus ex ipsum modi aliquid tenetur. Reiciendis, eaque?</p>
我该怎么做?
最佳答案
这应该适合您。我用过 touchmove、touchend 和 touchstart
。isTouchMove
是一个 bool 变量,用于检测用户是否使用触摸设备滚动。
// if user with a touch device is scrolling this is set to true
var isTouchMove = false;
// selectors
var body = document.querySelector('body');
var a = document.querySelector('a');
// set "isTouchMove" to true when you are scrolling
body.addEventListener("touchmove", function() {
isTouchMove = true;
});
// fire event on touch and set "isMoveTouch" to false
a.addEventListener("touchstart", function() {
isTouchMove = false;
});
// fire event when you leave the link
a.addEventListener("touchend", function() {
if(isTouchMove) return;
// your stuff
});
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit. Blanditiis unde, natus iusto, laborum dignissimos praesentium nam animi, ipsa inventore eius nihil! Sit nam voluptate eveniet sunt a tempore iure quibusdam!</p>
<p>Ratione inventore earum, non eveniet omnis incidunt dicta debitis, ipsum suscipit quas tenetur amet provident officiis labore, veritatis commodi consequatur! Ea dolorum, quis rerum minus quasi consequuntur eius odio reiciendis.</p>
<br>
<a href="http://nestordominguez.com" target="_blank">Click here</a>
<br>
<p>Laboriosam dicta officiis amet fuga! Atque officia, cupiditate recusandae vitae laboriosam dolorem tenetur minus. Perspiciatis nesciunt tenetur deserunt placeat similique ipsa reprehenderit! Esse ducimus laboriosam nulla, autem quibusdam corporis totam.</p>
<p>Aliquam dignissimos ex non magnam, rerum odio voluptates ducimus aspernatur. Dolorem quas, molestias dicta recusandae dolorum earum adipisci modi nemo alias accusantium eaque. At eos, dolorum et culpa quaerat recusandae!</p>
<p>Veniam tempora numquam aliquam perferendis, dolor voluptatem at, eligendi explicabo sunt minima nam debitis possimus nemo esse doloribus itaque consectetur odio rerum dolorum quasi facere saepe quidem. Laborum, cum, asperiores?</p>
<p>Magni, delectus. Illo sed blanditiis quae pariatur amet ratione quis perspiciatis error veritatis non laborum quibusdam ea, suscipit sequi esse velit doloribus ducimus ex ipsum modi aliquid tenetur. Reiciendis, eaque?</p>
关于javascript - 在纯 JS 中通过 <a> 标记触发 touchstart 事件时如何防止滚动而不是链接跟随?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38101841/
我目前正在我的设备 (Samsung galaxy S2) 上为我的游戏测试触摸启动功能。我在 android 中使用封装在 phonegap 下的 javascript 和 jquery 进行编程,
我用过这个link在我的项目中向左/向右写入的 stackoverflow 的内容,但现在我希望每次滑动 1 秒后处于非事件 touchstart 状态,并在 1 秒后 touchstart 处于事件
Angular 触控 ngTouch导致在触摸释放时发生点击。 有没有办法让点击发生在触摸开始? fast-click下面的指令似乎可以在触摸屏上执行我想要的操作,但它不适用于鼠标点击。 myApp.
如果您使用以下语法,一个简单的 touchstart 事件就可以工作: http://jsfiddle.net/rwdu4hb9/ $(function(){ $('.test').on('t
由于大多数桌面浏览器尚不支持 touchstart/touchend。如何创建与 mousedown 事件相同的 touchstart 事件(所有浏览器都支持)。 我想要这样的东西 $('obj').
我想在用户向下滚动移动设备页面时禁用 touchstart 事件。该页面有各种元素,当您单击时会切换一个类,但我希望当用户向下滑动以向下滚动页面时禁用这些 touchstart 事件。 JQUERY
所以我正在使用 JQuery (1.11.3),但我一直被困在网上找不到任何东西的东西上。 基本上,我将一个处理程序绑定(bind)到“touchstart”事件并想要检索触摸事件的位置。 (注意:我
我已将 touchstart 事件附加到网络应用程序中固定位置的页脚 所以结构是这样的: i am a looong content. i am tappable! 代码如下: $("#footer"
我倾向于制作一个输入字段和一个适用于移动浏览器的按钮。当我在字段中输入 123 并单击按钮时,它应该转到 http://example.com/123.html 然后我将这两个线程结合起来 24266
我将 Seadragon Ajax 与 jQuery 触摸事件监听器结合使用。 容器绑定(bind)了 touchstart、touchmove 和 touchend,这里是 touch start:
我已尝试在我的代码中进行滑动操作,但 touchstart 未初始化。我尝试在 stackoverflow 中搜索解决方案,但找不到任何解决方案。我是使用js的新手。这是链接: Sample wind
我正在将 Chrome 应用程序转换为 Electron 。该应用程序本身以全屏信息亭模式运行提供的 URL(带有一些其他配置选项)。我希望能够在 webview 的父元素上检测渲染器进程中的点击,但
今天突然之间,我开始在我们网站的每个页面上看到这个 Added non-passive event listener to a scroll-blocking 'touchstart' event.
我想阻止 touchStart 事件,以防止 Safari 在某些条件下在 iOS 设备中弹出。 为此,我使用以下方法: $('.wrapper').on('touchstart', function
我在页面上有一系列 div,您可以向左滑动,这将显示下面的 div。当只有一个元素时,这种方法效果很好,但当有多个元素时,它们都会一致滑动,而不是单独滑动一个。 为了解决这个问题,我尝试了这里的想法:
有与此类似的问题,但解决方案要么涉及另一个库,要么改用点击事件 - 我想知道没有库是否可行。 我在图像上使用 touchstart 事件来检测 1.5 秒的点击,然后重新加载所述图像。然而,在大多数移
我想在我的 li 上添加 touchstart 事件,而不禁用父级上的滚动。 目前,它有效。我在 timeline 上有滚动条,我可以点击 li。 当我添加touchstart时,我可以点击其中一个l
我在触摸启动后播放一些音频时遇到问题。我有以下在 Chrome 57 中运行的代码: Play Media on user touch Click me to play audio! d
更新:这个问题发生在动态创建的元素上我有一个页面,我在其中将 ajax 中的产品加载到网格中。每个产品都是一个 div,我希望可以单击它以将其信息添加到购物车。 使用 Jquery click 事件一
我正在寻找适用于 iOS 的解决方案,例如悬停在“桌面世界”中。我的页面上有很多图像项目,当用户在图像上移动手指时,实际图像的不透明度为 0。(因此一次移动会隐藏所有项目:) ) 我尝试过这样的事情:
我是一名优秀的程序员,十分优秀!