Thinkphpフレームワークに基づいて、PCステーションとモバイルステーションの対応するページが同じリンクとして実現されています

thinkphpフレームワークに基づいて、PCステーションとモバイルステーションの対応するページは同じリンクとして実現され、ページは適応型ではありません。

通常、モバイルステーションとpcステーションには対応するコントローラーが必要ですが、Webサイトを迅速かつ効率的に完成させるために、モバイルステーションとpcステーションには同じコントローラーを使用します。

まず、ページの命名規則では、モバイルステーションとPCステーションに対応するHTMLファイルに同じ名前を付ける必要があります。たとえば、About Usページ、携帯電話の名前はabout.html、PCステーションのabout usの名前もabout.htmlにする必要があります。

次に、pcとモバイルステーションに対応するページファイル(フォルダー)を、フロントエンドモジュール(通常、独自のディレクトリ構造に従ってインデックスまたはホーム)の下のビューフォルダーに配置する必要があります。たとえば、ここにはpcフォルダーとmフォルダーがあり、それぞれpcステーションとモバイルステーションの静的ページフォルダーに対応しています。
ここに画像の説明を挿入
ここでも、フロントエンドモジュールの下にある構成ファイルのテンプレートパスを再構成します(私はインデックスモジュールです)。

return[
    'template'=>[
        'view_path'    => VIEW_PATH,
    ]
];

最後に、基本クラスまたはcommon.phpファイルで、電話またはコンピューターがどちらであるかを判別し、別のモジュールにジャンプする必要があります。common.phpファイルで構成しました(パス; application / common.php)

//判断手机还是pc,可以换成自己的方法或者其他判断方法
function isMobile() {
    
    
    // 如果有HTTP_X_WAP_PROFILE则一定是移动设备
    if (isset($_SERVER['HTTP_X_WAP_PROFILE'])) {
    
    
        return true;
    }
    // 如果via信息含有wap则一定是移动设备,部分服务商会屏蔽该信息
    if (isset($_SERVER['HTTP_VIA'])) {
    
    
        // 找不到为flase,否则为true
        return stristr($_SERVER['HTTP_VIA'], "wap") ? true : false;
    }
    // 脑残法,判断手机发送的客户端标志,兼容性有待提高。其中'MicroMessenger'是电脑微信
    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','MicroMessenger');
        // 从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;
}

//根据不同设备,跳转不同的路径
if(!isMobile()){
    
    
    //$this->viewtype='mobile@';
    define('VIEW_PATH','../application/index/view/pc/view');//此处换成自己的pc模块路径
}else{
    
    
    define('VIEW_PATH','../application/index/view/m/view/');//此处换成自己的手机模块路径
}

この構成が完了すると、pcステーションとモバイルステーションの対応するページを同じリンクとして実現できます。

おすすめ

転載: blog.csdn.net/qq_36129701/article/details/106665214