Как обнаружить мобильное устройство на веб-странице

Для веб-сайта я хочу использовать определенные правила CSS для мобильных устройств. Я хочу следующее:

  • создать ссылку на номер телефона и сделать ее доступной для мобильных устройств.
  • пример кода: <a href="tel:+1234567890">+1234567890</a> (аналогично mailto: [email protected])
  • Нажав эту ссылку на обычном компьютере, возможно, появится сообщение об ошибке, в котором говорится, что они не знают tel-протокол.

Я хочу использовать CSS, чтобы скрыть номер телефона со ссылкой на немобильные устройства и отобразить другой элемент с простым номером телефона. Я мог бы использовать опцию media = "handheld", но, похоже, Android и iOS игнорируют это. Чистый CSS-метод является предпочтительным, но это не проблема, если требуется Javascript (или JQuery).

Теперь мой вопрос касается этой tel-link, но я, вероятно, буду использовать тот же метод для других изменений в таблице стилей для мобильных устройств.

Ответы

Ответ 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!";
}
?>

Я сделал это с помощью моего помощника, если у вас есть советы или исправления для меня, пожалуйста, дайте в комментариях:)

Ответ 2

Если вы просто хотите селектор для href с помощью "tel", вы можете использовать css attr "начинается с" селекторов, например...

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

См. мой пример здесь: http://jsfiddle.net/blowsie/gn9Ld/

Ответ 4

возможно, вы можете использовать callto:

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

так как вы разрабатываете для мобильных устройств, я думаю, вы должны прочитать в CSS3 Media Queries, если вы еще этого не сделали.

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