如何检测网页中的移动设备

时间:2011-06-22 12:25:47

标签: javascript jquery html css

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

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

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

我现在的问题是这个电话链接,但我可能会使用相同的方法对移动设备的样式表进行其他更改。

4 个答案:

答案 0 :(得分:7)

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

$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!";
}
?>

我是在我的配偶的帮助下做到的,如果你有我的提示或更正,请在评论中提出:)

答案 1 :(得分:3)

如果您只想使用“tel”的href选择器,您可以使用css attr“start with”选择器,如此...

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

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

答案 2 :(得分:3)

答案 3 :(得分:0)

也许你可以使用callto:

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

因为您正在为移动设备开发,我认为您应该阅读CSS3媒体查询,如果您还没有这样做。

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