- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我正在编写一个网站,该网站旨在用于台式机和平板电脑。当从桌面访问它时,我希望屏幕的可点击区域亮起 :hover
效果(不同的背景颜色等) 对于平板电脑,没有鼠标,所以我不想要任何悬停效果。
问题是,当我点击平板电脑上的某些东西时,浏览器显然有某种“隐形鼠标光标”,它会移动到我点击的位置,然后将其留在那里——所以我刚刚点击的东西会亮起悬停效果,直到我点击其他东西。
如何在使用鼠标时获得悬停效果,而在使用触摸屏时抑制它们?
如果有人想提出建议,我不想使用用户代理嗅探。同一个设备可以同时具有触摸屏和鼠标(今天可能不那么常见,但将来会更多)。我对设备不感兴趣,我对它目前的使用方式感兴趣:鼠标或触摸屏。
我已经试过 Hook touchstart
, touchmove
, 和 touchend
事件和调用 preventDefault()
在所有这些上,有时确实会抑制“隐形鼠标光标”;但是如果我在两个不同的元素之间快速来回轻敲,轻敲几下它就会开始移动“鼠标光标”并无论如何都会点亮悬停效果——就像我的 preventDefault
并不总是受到尊重。除非必要,否则我不会让你厌烦细节——我什至不确定这是正确的方法;如果有人有更简单的解决方法,我会全力以赴。
编辑:这可以用沼泽标准 CSS :hover
重现,但这里有一个快速复制供引用。
<style>
.box { border: 1px solid black; width: 150px; height: 150px; }
.box:hover { background: blue; }
</style>
<div class="box"></div>
<div class="box"></div>
mouseenter
,
mousemove
和
mouseleave
.
最佳答案
我从您的问题中得知您的悬停效果会更改您页面的内容。在这种情况下,我的建议是:
touchstart
上添加悬停效果和 mouseenter
. mouseleave
上的悬停效果, touchmove
和 click
. touchstart
touchmove
touchend
mouseover
mouseenter
mouseover
, mouseenter
或 mousemove
事件更改页面内容,永远不会触发以下事件。 mousemove
mousedown
mouseup
click
touchstart
上添加悬停效果和 mouseenter
. mouseleave
上的悬停效果, touchmove
和 click
. touchend
没有任何操作。 !
mouseenter
和
mouseleave
(
mouseover
和
mouseout
的略微改进版本)被触发,并添加和删除悬停。
click
s 一个链接,悬停效果也被删除。这可确保在用户按下 Web 浏览器中的后退按钮时将其删除。
mouseenter
上再次添加,并且由于这不会导致内容更改(已添加),因此
click
事件也会被触发,并且无需用户再次单击即可跟踪链接!
touchstart
之间的 300 毫秒延迟事件和
click
实际上是很好用的,因为悬停效果会在这么短的时间内显示出来。
mouseleave
事件被触发,并且悬停效果保持原位。幸运的是,这可以通过移除
touchmove
上的悬停效果轻松解决。 .
touchend
中的点击事件:这将错误地跟随链接,即使用户只想滚动或缩放,而无意实际单击链接。 touchend
中设置了一个变量在随后的鼠标事件中用作 if 条件以防止该时间点的状态更改。该变量在点击事件中被重置。请参阅本页上 Walter Roman 的回答。如果您真的不想在触摸界面上出现悬停效果,这是一个不错的解决方案。不幸的是,如果 touchend
,这将不起作用。由于另一个原因被触发并且没有触发点击事件(例如用户滚动或缩放),并且随后尝试使用鼠标跟踪链接(即在具有鼠标和触摸界面的设备上)。 mouseover
期间内容更改后不会触发更多事件。或 mousemove
事件。 关于javascript - 禁用移动浏览器上的悬停效果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8291517/
在gdb中获取此消息。我知道它不是错误或任何东西。我也做了分页,所以那不是问题。 有什么办法可以抑制此消息? 最佳答案 我很好奇看到这个问题没有得到解决... 我获得了GDB manual,它说(部分
好吧,这很烦人,而且可能很简单。我想用禁用的复选框启动我的网页,并在选择列表框中的特定行后启用这些框。所以我把它放在 onload 方法中 onload = function () { for
看来我需要以某种方式在我的 php 页面上禁用 IPv6,但我不确定该怎么做。我想我必须在我的 INI 文件中的某处添加 --disable-ipv6 ……虽然这看起来不像正确的语法。 我正在尝试解决
我有这两个代码: 第一个是禁用复制粘贴的宏: Sub Desable_Copy() Dim oCtrl As Office.CommandBarControl For Each oCt
在下面的代码中,我想, 如果我选择/单击“患者类型”按钮。它们在菜单“xmenumain”“儿科心电图”项中应该被禁用(它应该列在菜单列表中,但颜色为淡灰色)。我如何实现它? void MyMenu:
我目前在 Coordinator 布局中有一个底部导航栏,我向其添加了 HideBottomViewOnScrollBehaviour。有些屏幕需要隐藏导航栏,我可以通过从 BottomNavigat
我需要一些关于 jquery if 条件的帮助。我已经搜索和测试了几个小时,任何帮助都会很棒!我得到这个 HTML 代码: Value: No Match Test Test 2 Test 3
我正在开发 Delphi -7 中的自定义组件我有一些published特性 private { Private declarations } FFolderzip ,Fi
尝试学习菜单处理的基础知识。我的测试应用程序的菜单栏有 3 个菜单——即“TestApp”、“File”和“Help”。我发现我可以完全删除这些菜单,只需调用 say: NSMenu* rootMen
我以编程方式创建一个 NSMenuItem,但它被禁用。如果我重写 validateMenuItem: 方法并为所有项目返回 YES,则菜单项工作正常。 当我告诉菜单 autoEnableItems
我的 Web 表单中有一个 asp 按钮 (runat="server") 进入更新面板。 当我点击这个按钮时,它会执行一些操作。 Private Sub ButtonDoI
我目前正在为 video.js 构建一个插件,它可以在某些断点处将覆盖层呈现在屏幕上。但是,在不启动视频的情况下,我无法单击任何叠加层。我认为我需要禁用播放器上的点击播放功能。 我应该如何禁用/启用
设置剑道网格 selectable: "row", navigatable: true, 允许选择列标题单元格并通过键盘切换其排序状态。如何完全禁用使用键盘选择列标题单元格的功能? 最
我不想卸载code rush。我只是想在不需要的时候有机会将其关闭。 这可能吗? (快速版本)... 最佳答案 首先您应该打开“DevExpress”菜单。默认情况下,它在 CodeRush Xpre
设置: 我正在使用 TinyMCE 的 Angular 包装器来允许我的用户构建自己的电子邮件模板。这些电子邮件会发送给每个用户组织内的多个人员。我创建了自定义工具栏按钮来插入小文本 block [[
我希望下拉菜单在悬停时打开,前提是窗口大于 767 像素。我试图在页面加载和窗口调整大小时调用一个函数,并使用宽度大小条件。 enableHover() 函数仅适用于页面加载,不适用于窗口调整大小。
由于我遇到了一些问题,我正在 .NET Framework 4 中尝试连接池。使用 SQL Profiler,我可以看到每次从连接池中获取连接时,都会执行存储过程 sp_reset_connectio
我避免在我的 swift 代码中收到警告。然而,当谈到 Storyboard要求时,这对我来说有点困难。 所以现在我只想禁用 xcode 显示有关 Storyboard问题的警告。 我尝试了以下方法但
我不是 JavaScript 专家,我目前正在尝试为表单创建一个函数,该函数根据上一页上选择的数字重复相同的字段。 表单字段可能有 1 到 10 行,每行都有一个单选按钮选择,可启用/禁用每一行。 目
我正在尝试使用 CPU2006 运行各种基准测试,以查看各种优化在 gcc 速度方面的作用。我熟悉 -O1、-O2 和 -O3,但听说 -msse 是一个不错的优化。 -msse 到底是什么?我还看到
我是一名优秀的程序员,十分优秀!