15621857753

phpcmsV9如何使用双模板制作PC站与移动站

来源:齐鲁建站 栏目:开发教程 阅读: 日期:2021-04-11

本文介绍了phpcmsV9如何使用双模板制作PC站与移动站,教程给出了非常详细的步骤,根据说明一步一步来制作吧。

下面齐鲁建站就和大家分享下phpcmsV9如何使用双模板制作PC站与移动站。

实现教程:

第一步:网址解析

绑定三个网址:http://www.域名、http://m.域名、http://域名。

第二步:做网址伪原创

栏目伪原创后网址如:http://www.域名/list-1-1.html,内容页网址:http://www.域名/show-1-1-1.html。对应移动站网址:栏目伪原创后网址如:http://m.域名/list-1-1.html,内容页网址:http://m.域名/show-1-1-1.html。至于怎么伪原创不是本文的重点,不会伪原创另外讨论。

第三步:修改phpcms/modules/content/index.php。在31行处找到include template('content','index',$default_style);修改为:

if(substr($_SERVER['SERVER_NAME'], 0,1) == 'm'){

include template('content_m','index',$default_style);

}else{

include template('content','index',$default_style);

}

分别在203、265、278行处把include template('content',$template);修改为:

if(substr($_SERVER['SERVER_NAME'], 0,1) == 'm'){

include template('content_m',$template);

}else{

include template('content',$template);

}

意思是,当域名头部为m时选择 content_m文件夹里的模板,www时选择content文件夹的模板。

第四步:把存放模板的文件夹content复制一份,重命名为content_m,里面的模板文件名一样,里面基本文件header.html,footer.html,index.html,category.html,list.html,show.html。content文件夹内模板为PC板调用,content_m为移动站调用,移动板文件建议用html5制作。

第五步:在PC板模板加入跳转脚本

判断为移动端自动跳转网址

脚本写法:<script src="{JS_PATH}uaredirect.js" type="text/javascript"></script>

<script type="text/javascript">uaredirect("要跳转到的移动站网址");</script>

首页、单页、栏目页、内容页各自调用单独的头部模板,方便写跳转网址。

1、首页跳转的网址写法为:<script type="text/javascript">uaredirect("http://m.域名/index.php");</script>

2、单页、栏目页跳转的网址写法为:<script type="text/javascript">uaredirect("http://m.域名/list-{$catid}-{$page}.html");</script>

3、内容页跳转的网址写法为:<script type="text/javascript">uaredirect("http://m.域名/show-{$catid}-{$id}-{$page}.html");</script>

脚本uaredirect.js的文本为:

function uaredirect(f){try{if(document.getElementById("bdmark")!=null){return}var b=false;if(arguments[1]){var e=window.location.host;var a=window.location.href;if(isSubdomain(arguments[1],e)==1){f=f+"/#m/"+a;b=true}else{if(isSubdomain(arguments[1],e)==2){f=f+"/#m/"+a;b=true}else{f=a;b=false}}}else{b=true}if(b){var c=window.location.hash;if(!c.match("fromapp")){if((navigator.userAgent.match(/(iPhone|iPod|Android|ios)/i))){location.replace(f)}}}}catch(d){}}function isSubdomain(c,d){this.getdomain=function(f){var e=f.indexOf("://");if(e>0){var h=f.substr(e+3)}else{var h=f}var g=/^www\./;if(g.test(h)){h=h.substr(4)}return h};if(c==d){return 1}else{var c=this.getdomain(c);var b=this.getdomain(d);if(c==b){return 1}else{c=c.replace(".","\\.");var a=new RegExp("\\."+c+"$");if(b.match(a)){return 2}else{return 0}}}};

个人建议脚本尽量放在靠前位置比较好吧,因为加载网页时尽早触发脚本,跳转到移动网页会不会快点呢,这是我的个人意见,不知对否请高手指正。

第六步:content_m中模板调用的更改

由于phpcms把文章的url都固定写死在数据表中.所以,页面中的标签不能在使用{$r[url]},而要改成{str_replace('http://www.','http://m.',$r[url])},意思是,截取url,把http://www.替换成http://m.,其它琏链接的标签参考此法。

PC版首页可以生成静态,也可以是动态。双模板伪原创好处是写百度适配非常简单,直接三句:

http://www.域名对http://m.域名

http://www.域名/list-(\d+)-(\d+).html对http://m.域名/list-${1}-${2}.html

http://www.域名/show-(\d+)-(\d+)-(\d+).html对http://m.域名/show-${1}-${2}-${3}.html

当然PC站静态也可以的,不过移动站就不能静态或伪静态了,因为只能生成一个静态页面,起码我不会弄,但可以跳转到移动站的动态网址,跳转网址可以参考伪静态的,无非是三个参数的对应。好了,这是我用双模板制作PC手移动站的一点点心得,完胜系统自带的手机门户站吧,手机站和PC站一样的标签调用。如有看不懂的地方可以提问。

展开