PHP代码判断设备是手机还是平板电脑(两种方法)


Posted in PHP onOctober 19, 2015

现在移动互联网越来越发达,很多的网站都普及了手机端浏览,为了更好的让网页在手机端显示,我们都选择了使用CSS媒体查询制作响应式模版,但这也有弊端,例如某些网站的结构是CMS类型的,太多的内容要显示,而使用CSS媒体查询设计响应式,只会隐藏但还是加载了,为了让手机端更快速的显示出内容,我们可以使用这个PHP判断手机设备代码,使用这个代码可以很方便的显示或不显示自定义的内容。

在做WEB开发的时候经常会需要用到对移动设备的页面匹配,当然可以直接把网站做成响应式的,但如果不想这么做的话,可以使用PHP对设备类型进行判断, 然后显示相应的界面和内容。今天分享一种使用 PHP 判断设备是否是手机/平板的方法,方法来源于WordPress(wp-includes/vars.php:125),适用于大部分类型的手机/平板判 断:

方法一:

/**
 * Test if the current browser runs on a mobile device (smart phone, tablet, etc.)
 *
 * @staticvar bool $is_mobile
 *
 * @return bool
 */
function wp_is_mobile() {
 static $is_mobile = null;
 
 if ( isset( $is_mobile ) ) {
  return $is_mobile;
 }
 
 if ( empty($_SERVER['HTTP_USER_AGENT']) ) {
  $is_mobile = false;
 } elseif ( strpos($_SERVER['HTTP_USER_AGENT'], 'Mobile') !== false // many mobile devices (all iPhone, iPad, etc.)
  || strpos($_SERVER['HTTP_USER_AGENT'], 'Android') !== false
  || strpos($_SERVER['HTTP_USER_AGENT'], 'Silk/') !== false
  || strpos($_SERVER['HTTP_USER_AGENT'], 'Kindle') !== false
  || strpos($_SERVER['HTTP_USER_AGENT'], 'BlackBerry') !== false
  || strpos($_SERVER['HTTP_USER_AGENT'], 'Opera Mini') !== false
  || strpos($_SERVER['HTTP_USER_AGENT'], 'Opera Mobi') !== false ) {
   $is_mobile = true;
 } else {
  $is_mobile = false;
 }
 
 return $is_mobile;
}

代码二:

这是PHP判断手机设备函数代码,复制到PHP函数库中调用:

<?php
function is_mobile() {
$user_agent = $_SERVER['HTTP_USER_AGENT'];
$mobile_browser = Array(
"mqqbrowser", //手机QQ浏览器
"opera mobi", //手机opera
"juc","iuc",//uc浏览器
"fennec","ios","applewebKit/420","applewebkit/525","applewebkit/532","ipad","iphone","ipaq","ipod",
"iemobile", "windows ce",//windows phone
"240×320","480×640","acer","android","anywhereyougo.com","asus","audio","blackberry","blazer","coolpad" ,"dopod", "etouch", "hitachi","htc","huawei", "jbrowser", "lenovo","lg","lg-","lge-","lge", "mobi","moto","nokia","phone","samsung","sony","symbian","tablet","tianyu","wap","xda","xde","zte"
);
$is_mobile = false;
foreach ($mobile_browser as $device) {
if (stristr($user_agent, $device)) {
$is_mobile = true;
break;
}
}
return $is_mobile;
}?>

这是调用代码,可以加上if判断:

<?php if(is_mobile()):?>

设置手机端的内容

<?php endif; ?>

以上所述就是本文的全部内容,希望大家喜欢。

PHP 相关文章推荐
PHP与javascript对多项选择的处理
Oct 09 PHP
PHP 作用域解析运算符(::)
Jul 27 PHP
PHP静态调用非静态方法的应用分析
May 02 PHP
smarty基础之拼接字符串的详解
Jun 18 PHP
php中的Base62类(适用于数值转字符串)
Aug 12 PHP
php中数据库连接方式pdo和mysqli对比分析
Feb 25 PHP
PHP使用mysql_fetch_row查询获得数据行列表的方法
Mar 18 PHP
php实现复制移动文件的方法
Jul 29 PHP
php用户注册信息验证正则表达式
Nov 12 PHP
PHP递归实现层级树状展开
Apr 01 PHP
Yii2.0 模态弹出框+ajax提交表单
May 22 PHP
PHP unset函数原理及使用方法解析
Aug 14 PHP
基于PHP实现假装商品限时抢购繁忙的效果
Oct 16 #PHP
php如何连接sql server
Oct 16 #PHP
Apache启动报错No space left on device: AH00023该怎么解决
Oct 16 #PHP
PHP 中 Orientation 属性判断上传图片是否需要旋转
Oct 16 #PHP
全面解读PHP的人气开发框架Laravel
Oct 15 #PHP
php示例详解Constructor Prototype Pattern 原型模式
Oct 15 #PHP
PHP经典面试题之设计模式(经常遇到)
Oct 15 #PHP
You might like
递归列出所有文件和目录
2006/10/09 PHP
使用迭代器 遍历文件信息的详解
2013/06/08 PHP
JS的replace方法详细介绍
2012/11/09 Javascript
jquery与prototype框架的详细对比
2013/11/21 Javascript
javascript:void(0)的问题使用探讨
2014/04/10 Javascript
用html+css+js实现的一个简单的图片切换特效
2014/05/28 Javascript
node.js中的url.parse方法使用说明
2014/12/10 Javascript
EasyUi datagrid 实现表格分页
2015/02/10 Javascript
jQuery实现的在线答题功能
2015/04/12 Javascript
javascript绘制漂亮的心型线效果完整实例
2016/02/02 Javascript
ClearTimeout消除闪动实例代码
2016/02/29 Javascript
使用NodeJs 开发微信公众号(三)微信事件交互实例
2016/03/02 NodeJs
Angular设置title信息解决SEO方面存在问题
2016/08/19 Javascript
jQuery编写textarea输入字数限制代码
2017/03/23 jQuery
vuex学习之Actions的用法详解
2017/08/29 Javascript
JavaScript偏函数与柯里化实例详解
2019/03/27 Javascript
微信小程序登录数据解密及状态维持实例详解
2019/05/06 Javascript
React传值 组件传值 之间的关系详解
2019/08/26 Javascript
详解Nuxt.js 实战集锦
2019/11/19 Javascript
js实现复制粘贴的两种方法
2020/12/04 Javascript
go和python变量赋值遇到的一个问题
2017/08/31 Python
python PyTorch预训练示例
2018/02/11 Python
python3爬虫获取html内容及各属性值的方法
2018/12/17 Python
Flask-WTF表单的使用方法
2019/07/12 Python
python 数据生成excel导出(xlwt,wlsxwrite)代码实例
2019/08/23 Python
Python 多线程搜索txt文件的内容,并写入搜到的内容(Lock)方法
2019/08/23 Python
简单了解Pandas缺失值处理方法
2019/11/16 Python
HTML5实现视频直播功能思路详解
2017/11/16 HTML / CSS
HTML5中5个简单实用的API
2014/04/28 HTML / CSS
俄罗斯的精英皮具:Wittchen
2018/01/29 全球购物
澳洲小众品牌的集合网站:BNKR
2018/02/23 全球购物
Tea Collection官网:一家位于旧金山的童装公司
2020/08/07 全球购物
团队队名口号大全
2014/06/06 职场文书
合作协议书模板2014
2014/09/26 职场文书
利用python进行数据加载
2021/06/20 Python
关于python类SortedList详解
2021/09/04 Python