【问题标题】:Detect if browser/device supports double click events检测浏览器/设备是否支持双击事件
【发布时间】:2012-12-30 11:56:39
【问题描述】:

我有一个包含多行的表。 每一行都可以通过在行上单击一次来选择。 双击该行会在同一窗口中打开该行所代表的数据表。

使用移动设备时,双击(双击?)不会触发我的双击事件,而移动浏览器只是缩放。

经过深思熟虑,我认为移动设备通过单击/点击打开数据表更有意义。

现在我正在检测它是否是移动设备浏览器,在为表设置事件侦听器时,使用以下代码:

if( /Android|webOS|iPhone|iPad/i.test(navigator.userAgent) ) {
    // Single click event bind, open
} else {
    // Single click event bind, select
    // Double click event bind, open
}

与其依赖用户代理,我更愿意做一些特征检测,这样任何无法双击的设备都可以工作。

我尝试检测 dblclick 事件在我的 Android 设备上是否可用,它是可用的。
我想这是有道理的,因为浏览器确实支持它,但设备只是在双击时触发不同的事件。

我唯一能想到的另一件事是检查touchstart 等事件是否可用,但这似乎与检查用户代理一样错误。

有什么好的方法可以检测浏览器/客户端是否按预期支持双击?

【问题讨论】:

  • 你使用这个活动吗? $(榆树).dblclick();
  • @HodayaShalom 是的,这就是我正在使用的 jQuery 事件。将 jQuery 添加到我的标签中,以澄清 jQuery 在我的情况下可用。

标签: javascript android jquery ios mobile


【解决方案1】:

也许尝试使用超时来检查在第一次点击后是否还有另一次点击

$(Elm).click(function(evnt){
  clicks++;
  if (clicks == 1) {
    setTimeout(function(){
      if(clicks == 1) 
        // Single click event bind, open
       else 
         // Double click event bind, open
    },2000);
});

【讨论】:

  • 感谢您的回答!但是对于支持双击的设备,上述操作不会使单击(选择一行)成为不可能吗?
  • 我不知道设备是否可以双击,但是您可以绕过单击并检查它是否是双击..
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2014-10-05
  • 2011-12-12
  • 2011-09-07
  • 1970-01-01
  • 1970-01-01
  • 2011-06-06
  • 1970-01-01
相关资源
最近更新 更多