【问题标题】:How to detect a mobile device in a web page如何检测网页中的移动设备
【发布时间】:2011-06-22 12:25:46
【问题描述】:

对于一个网站,我想为移动设备使用特定的 CSS 规则。我想要的是以下内容:

  • 在电话号码上创建一个链接,并使其可在移动设备上点击
  • 代码示例:<a href="tel:+1234567890">+1234567890</a>(类似于mailto:john@hotmail.com)
  • 在普通计算机上单击此链接可能会产生一条错误消息,指出他们不知道电话协议。

我想使用 CSS 在非移动设备上隐藏带有链接的电话号码,并使用普通电话号码显示另一个元素。我可以使用 media="handheld" 选项,但 Android 和 iOS 似乎忽略了这一点。首选干净的 CSS 方法,但如果需要 Javascript(或 JQuery)也没问题。

我现在的问题是关于这个 tel-link,但我可能会使用相同的方法对移动设备的样式表进行其他更改。

【问题讨论】:

  • 您需要为移动设备使用某种框架,并希望它能解决问题。从头开始自己支持每种类型会有点详尽。
  • 我不明白。 CSS 与电话号码链接有什么关系?您的意思是您只想在移动设备上使用 CSS 将样式应用于这些链接?
  • 您不能使用 CSS 创建链接。并非所有移动设备都支持 tel: 方案。并非所有非移动设备都不支持 tel: 方案。
  • 除了 Quentin 说的,在不支持的浏览器中有链接有什么害处?它根本行不通,出现类似于“此浏览器不支持‘tel’协议”的错误消息,这听起来或多或少对我来说是可以理解的。
  • CSS 不能创建链接是正确的,但它可以隐藏元素。所以它可以隐藏 a-tel-element,并显示另一个没有链接的带有电话号码的元素。

标签: javascript jquery html css


【解决方案1】:

这是我用来检查给定请求是否来自移动设备的:

$mobile_browser = '0';

if (preg_match('/(up.browser|up.link|mmp|symbian|smartphone|midp|wap|phone|android)/i', strtolower($_SERVER['HTTP_USER_AGENT']))) {
    $mobile_browser++;
}

if ((strpos(strtolower($_SERVER['HTTP_ACCEPT']),'application/vnd.wap.xhtml+xml') > 0) or ((isset($_SERVER['HTTP_X_WAP_PROFILE']) or isset($_SERVER['HTTP_PROFILE'])))) {
    $mobile_browser++;
}    

$mobile_ua = strtolower(substr($_SERVER['HTTP_USER_AGENT'], 0, 4));
$mobile_agents = array(
    'w3c ','acs-','alav','alca','amoi','audi','avan','benq','bird','blac',
    'blaz','brew','cell','cldc','cmd-','dang','doco','eric','hipt','inno',
    'ipaq','java','jigs','kddi','keji','leno','lg-c','lg-d','lg-g','lge-',
    'maui','maxo','midp','mits','mmef','mobi','mot-','moto','mwbp','nec-',
    'newt','noki','oper','palm','pana','pant','phil','play','port','prox',
    'qwap','sage','sams','sany','sch-','sec-','send','seri','sgh-','shar',
    'sie-','siem','smal','smar','sony','sph-','symb','t-mo','teli','tim-',
    'tosh','tsm-','upg1','upsi','vk-v','voda','wap-','wapa','wapi','wapp',
    'wapr','webc','winw','winw','xda ','xda-');

if (in_array($mobile_ua,$mobile_agents)) {
    $mobile_browser++;
}

if (strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'windows') > 0) {
    $mobile_browser = 0;
}

if (strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'mac') > 0) {
        $mobile_browser = 0;
}

if (strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'ios') > 0) {
        $mobile_browser = 1;
}
if (strpos(strtolower($_SERVER['HTTP_USER_AGENT']),'android') > 0) {
        $mobile_browser = 1;
}

if($mobile_browser == 0)
{
    //its not a mobile browser
    echo"You are not a mobile browser";
} else {
    //its a mobile browser
    echo"You are a mobile browser!";
}
?>

我是在我的一个伙伴的帮助下完成的,如果您对我有任何建议或更正,请在 cmets 中提供:)

【讨论】:

  • 那是 PHP,但这不是问题。
  • 我在我的开发机器上试过(ubuntu 11.04 和 firefox 4)。当我在浏览器中运行该代码时,我得到一个 1,这意味着我的桌面运行的是移动浏览器。
  • 抱歉,代码有问题;我确实得到一个 0,所以不是移动设备。
  • 如果它对你有用,那就太好了:) 请标记为答案,以便其他人也能找到它。
  • 在 XP/Firefox、XP/IE6、Ubu/Chrome、Ubu/FF4、Android、Wine/Safari 和 Wine/IE7 上进行了测试,一切正常。
【解决方案2】:

如果你只想要一个使用“tel”的 href 选择器,你可以使用 css attr “starts with”选择器,就像这样......

a[href^="tel"] { color: red; }

在此处查看我的示例: http://jsfiddle.net/blowsie/gn9Ld/

【讨论】:

  • JSFiddle 很酷! :-) 你的例子很清楚,虽然不是我需要的,但我认为这不是一个大问题。
  • 与我之前的评论不同,我现在意识到您的建议并不能解决我的问题(使用移动浏览器的特定样式表)。它仍然很有用,因为它帮助我意识到我可以在链接中添加一个类并将光标设置为箭头。这样,桌面浏览器不会邀请用户单击它,而移动浏览器(不使用鼠标光标)仍然可以使用该链接。我是否将您的方法与 css 条件一起使用或添加一个类对我来说并不是那么重要。
【解决方案3】:
【解决方案4】:

也许你可以使用 callto:

<a href="callto://+112345767890">Call me at +112345767890</a>

由于您正在为移动设备开发,我认为如果您还没有阅读 CSS3 媒体查询,那么您应该阅读一下。

http://ubelly.com/2011/04/css3-media-queries-explained/?amp&amp

【讨论】:

  • callto skype 或 voip 是特定的还是没有区别?
  • 我刚刚尝试在超链接中使用“callto”和“tel”,在我的 Mac(Google Chrome / Firefox)上,它尝试使用 Skype 进行呼叫,但在我的 iPhone(Safari)上它表现得很好与使用“电话”完全相同。请注意,对我来说,前缀必须是“callto:”而不是“callto://”,因为后者在 Firefox 或 Chrome 中不起作用。
猜你喜欢
  • 1970-01-01
  • 2015-01-06
  • 1970-01-01
  • 2012-09-25
  • 1970-01-01
  • 2010-09-06
  • 2013-01-12
  • 2011-08-29
相关资源
最近更新 更多