手上一个项目需要在已有PC端的情况下开发手机端,需要识别使用的设备并加载不同模板文件
我的测试项目是这样的:

Index模块下的view是PC端的模板,手机端的模板文件是在wap模块下的。
话不多说,上代码!
1.先修改application目录下的common.php文件,加上下面这段代码:
function isMobile()
{
if (isset($_SERVER['HTTP_X_WAP_PROFILE'])) {
return true;
}
if (isset($_SERVER['HTTP_VIA'])) {
return stristr($_SERVER['HTTP_VIA'], "wap") ? true : false;
}
if (isset($_SERVER['HTTP_USER_AGENT'])) {
$clientkeywords = array('nokia', 'sony', 'ericsson', 'mot', 'samsung', 'htc', 'sgh', 'lg', 'sharp', 'sie-', 'philips', 'panasonic', 'alcatel', 'lenovo', 'iphone', 'ipod', 'blackberry', 'meizu', 'android', 'netfront', 'symbian', 'ucweb', 'windowsce', 'palm', 'operamini', 'operamobi', 'openwave', 'nexusone', 'cldc', 'midp', 'wap', 'mobile');
if (preg_match("/(" . implode('|', $clientkeywords) . ")/i", strtolower($_SERVER['HTTP_USER_AGENT']))) {
return true;
}
}
if (isset($_SERVER['HTTP_ACCEPT'])) {
if ((strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') !== false) && (strpos($_SERVER['HTTP_ACCEPT'], 'textml') === false || (strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') < strpos($_SERVER['HTTP_ACCEPT'], 'textml')))) {
return true;
}
}
return false;
}
代码主要作用就是判断是不是手机登录。
2,在Index.php中加上判断进行跳转。
public function index()
{
if(isMobile())
{
$this->assign('test','测试数据');
return $this->fetch('wap@index/index');//打开手机端模板
}
return $this->fetch();//打开PC端模板
}
由于模板文件在不同目录下,使用了tp5中的模板渲染方法,官方教程是这样的:
跨模块渲染模板
return $this->fetch('admin@member/edit');
渲染输出不需要写模板文件的路径和后缀。这里面的控制器和操作并不一定需要有实际对应的控制器和操作,只是一个目录名称和文件名称而已,例如,你的项目里面可能根本没有Public控制器,更没有Public控制器的menu操作,但是一样可以使用
刚开始并没有看懂,实际上,以我的测试项目为例,实际调用的模板文件目录应该是这样的:
test/application/wap/view/index/index.html
这里的index.html文件不用写后缀名,写上后会出现错误
3下面是手机端的代码和访问时的效果



本文介绍了一个项目在已有PC端基础上开发手机端的过程,通过识别设备类型来加载不同模板。在TP5.1中,通过修改common.php文件进行设备判断,并在Index.php中添加代码实现自动跳转。同时,详细解释了如何正确调用手机端的模板文件,避免出现错误。

595

被折叠的 条评论
为什么被折叠?



