TP5中手机端和PC端的实现方式

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/BearKChan/article/details/80915812

TP5中手机端和PC端判断是实现方式

一、使用自定义的判定方法

  1. 首先在application>common.php公共文件中写入用于判定设备登录的ismobile方法:

    
    function ismobile()
    
    {
    
        // 如果有HTTP_X_WAP_PROFILE则一定是移动设备
    
        if (isset ($_SERVER['HTTP_X_WAP_PROFILE']))
    
            return true;
    
    
    
        //此条摘自TPM智能切换模板引擎,适合TPM开发
    
        if (isset ($_SERVER['HTTP_CLIENT']) && 'PhoneClient' == $_SERVER['HTTP_CLIENT'])
    
            return true;
    
        //如果via信息含有wap则一定是移动设备,部分服务商会屏蔽该信息
    
        if (isset ($_SERVER['HTTP_VIA']))
    
            //找不到为flase,否则为true
    
            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'
    
            );
    
            //从HTTP_USER_AGENT中查找手机浏览器的关键字
    
            if (preg_match("/(" . implode('|', $clientkeywords) . ")/i", strtolower($_SERVER['HTTP_USER_AGENT']))) {
    
                return true;
    
            }
    
        }
    
        //协议法,因为有可能不准确,放到最后判断
    
        if (isset ($_SERVER['HTTP_ACCEPT'])) {
    
            // 如果只支持wml并且不支持html那一定是移动设备
    
            // 如果支持wml和html但是wml在html之前则是移动设备
    
            if ((strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') !== false) && (strpos($_SERVER['HTTP_ACCEPT'], 'text/html') === false || (strpos($_SERVER['HTTP_ACCEPT'], 'vnd.wap.wml') < strpos($_SERVER['HTTP_ACCEPT'], 'text/html')))) {
    
                return true;
    
            }
    
        }
    
        return false;
    
    }
    
  2. 然后在application>index>controller>Base.php前台index模块的基类控制器Base中重写fetch方法:

    
    /**
    
    *加载模板输出(电脑和手机)
    
    * @accessprotected
    
    * @paramstring$template模板文件名
    
    * @paramstring$mobiletemplate手机模板文件名
    
    * @paramarray$vars模板输出变量
    
    * @paramarray$replace模板替换
    
    * @paramarray$config模板参数
    
    * @returnmixed
    
    */
    
    protected
    
    function fetch($template = '', $mobiletemplate = '', $vars = [], $replace = [], $config = [])
    
    {
    
       if (ismobile()) {
    
           return $this->view->fetch($mobiletemplate, $vars, $replace, $config);
    
       } else {
    
           return $this->view->fetch($template, $vars, $replace, $config);
    
       }
    
    }
    
  3. 最后在application>index>controller>Index继承与基类Base的控制器Index的方法index中最后分别传入pc端的路径和mobile端的路径即可。

    
    return $this->fetch('default/index/index','mobile/index/index');
    

    前面的default/index/index是pc端对应的路径,后面的mobile/index/index是mobile端对应的路径。

二、使用TP5自带的判断方法(推荐使用,已优化)

通过上面的方法我们可以看出,虽然起作用,但是每次 都要传入两个路径,很是繁琐。

  1. 首先在application>common.php公共文件中写入用于判定设备登录的常量VIEW_PATH

    
    if (\think\Request::instance()->isMobile()) {
    
       define('VIEW_PATH', __DIR__ . '/../application/index/view/mobile/');
    
    } else {
    
       define('VIEW_PATH', __DIR__ . '/../application/index/view/default/');
    
    
    
    }  
    
  2. 接着在application>index>config.php模块index的配置文件config.php中进行模板变量的替换:

    
    return [
    
       "template"=>[
    
           // 模板路径
    
           'view_path' => VIEW_PATH,
    
       ],
    
    ];
    
  3. 最后在控制器的方法中只需要直接fetch一个路径即可。

    
    return $this->fetch();
    

Tip:前台页面的目录结构如图所示:

注意default和mobile下的目录结构保持一致

猜你喜欢

转载自blog.csdn.net/BearKChan/article/details/80915812