1.站点/发布点的新建
1.1 发布点的新建:
发布点是设置站点与服务器之间的链接配置。
设置 - 发布点管理 - 添加发布点
![]()
发布点名:可以与接下来的站点名称相同
ftp服务器:用于设置PHPcms链接ftp服务器的参数,这里分别需要设置服务器的地址(ip),端口(21),用户名,密码,以及站点文件在ftp的那个目录,然后再单击测试链接,
如果测试通过,则表示链接成功。
1.2 站点的新建:
用于设置网站站点的信息。
设置 - 站点管理 - 添加站点。

站点名:便是网站的名称。
站点目录:站点的根目录即可。
站点域名:便是网站的域名。
模板风格:选择本站点的模板风格
2. 模型/栏目页新建
2.1 新建模型
简历模型,相当于创建一个数据表,在模型中,我们可以配置所需要的一些字段属性,而且,栏目也是基于模型建立的,因为栏目需要的就是字段
内容- 模型管理 - 添加模型

分别设置好模型的名称,表的键名,以及关于该模型的描述
2.2 栏目的新建
栏目用于分类的保存数据,在建立栏目时,需要注意以下几点:
内容 - 管理栏目 - 添加栏目

· 选择模型建立的模型
· 选择是一级栏目还是属于某个一级栏目的子栏目
· 栏目名称:填写栏目的名称。
· 英文目录:栏目的url地址,例如如果填写news,则对于网站来说:www.xxx.com/news/
· 是否在导航显示:如果不勾选这个,那么在栏目管理界面中,将看不到栏目的具体URL信息。

· 栏目生成html,内容页面生成html,一定要勾选是
· 栏目页URL规则,内容页URL规则,可以设置生成栏目页与内容页的URL的格式。
· 是否生成根目录:
这个很重要,对于一级栏目而言肯定是生成到根目录下的。但是对于子栏目而言,肯定不是生成在根目录下的。
3. 广告位以及广告位模板
3.1 广告位模板
所有的广告位都是基于广告位模板的。
广告位模板的编写格式:
1
2
3
4
5
|
{loop $pinfo $p}
document.write(' //这里就是具体的模板内容 ');
{/loop}
|
广告位模板编写完成之后,要将其保存到网页模板目录content同级的poster目录中。
* 记着default中的与当前站点目录的poster目录都要放一份。
最后在管理系统中,更新缓存即可。
3.2 新建广告位
模块 - 广告
3.2.1 广告位模板设置
模板 - 广告 - 广告模板设置
对着所需更改的模板单击其右侧的设置按钮,打开如下界面:

· 中文名:可以为模板添加一个中文名称,方便记忆
· 可用广告类型:根据模板的实际情况勾选。
3.2.2 新建广告位
模块 - 广告 - 添加版位
一、SEO优化:
获取栏目的关键字:{$SEO['keyword']}
获取栏目的描述:{$SEO['description']}
判断栏目的title是否存在或为空,如果是的话,则用站点的title替代 :
{if isset($SEO['title']) && !empty($SEO['title'])}{$SEO['title']}{/if}{$SEO['site_title']}
二、模板加载:
{template "content" , "header_index"}
* header_index 要加载的模板名称。
* 该标签只能加载自定义的模板,对于预定义好的模板是不能进行加载的。
* 预定义的模板名称:
category_ 栏目页模板的名称都是如此命名
list_ 列表页的模板都是如此命名
article_ 内容页的模板都是如此命名
index.html 首页模板的命名
default.html 超首模板的命名
page_ 单页面的模板都是如此命名
show_ 内容页都是如此命名
三、PC 内容查询标签:
一般格式的查询:
{pc:content action="lists" catid="$catid" num="5" order="listorder,id DESC" page="$page" thumb="1" start="5"}
{loop $data $r}
{/loop}
{/pc}
* action 规定生成的动作,默认的是lists。如果取值 为position,表示读取推荐位中内容。那么catid就要改成了posid。
* catid 栏目ID,规定从哪个栏目中抽取数据。
* num 表示生成的数据条目的数量。
* order 表示排序的方式,DESC为降序,ASC为升序。
* page 如果指定了改属性,表示有分页。最终的分页数据则有分页标签进行调用。
* thumb 表示内容是否有缩略图。
* start 表示起始的位置。
万能查询语句:
万能查询实际上就是PC标签+SQL语言来直接对数据表进行查询。
{pc:get sql="select catname from v9_category where catid='$catid'" return "data"}
{loop $data $r}
{/loop}
{/pc}
* sql 中保存的是要执行的SQL语句。
- catname 要查询的字段
- v9_category 表名
- catid 记录的关键字段。
* data中保存的是返回到的数据,这些数据都会以一个数组的形式保存到$data中,然后以$r[catname]的方式进行调用。
四、页面相关的常用标签:
{siteurl($siteid)} 显示首页的URL地址。
{$catid} | {$CAT[catid]} 显示当前栏目的ID。
{$catname} | {$CAT[catname]} 显示栏目的名称(中文)。
{$catdir} | {$CAT[catdir]} 显示栏目的名称(英文)。
{$parentid} 拿到父栏目的id
{$top_parentid} 拿到顶级栏目的id
{$inputtime} 拿到文章输出时间
{$title} 拿到文章的标题
{$id} 拿到文章的文章ID
{$modelid} 拿到模型的模型ID
{catpos($catid)} 显示面包屑导航。
{$content} 加载内容。
{$page} 显示分页。
*注:{ } 该符号专用于页面展示标签数据时使用。运算判断无需添加。
=========== 依附于有数据 $data的标签 ================
{$r[title]} 显示文章的标题。
{str_cut($r[title],30,'.....')} 显示裁剪后的标题。
{$r[url]} 显示文章的链接。
{$r[thumb]} 显示文章的缩略图。
{$r[style]} 拿到内嵌样式
{thumb($r[thumb],90,90)} 显示裁剪后的缩略图。
{date("y-m-d h:m:s",$r[inputtime])} 格式化时间输出。
五、广告位调用:
{loop $pinfo $p}
document.write('<li><a href="{$p['setting'][1]['linkurl']}" class="fl" target="_blank">{$p['name']}</a><em class="fr">{$p['setting'][1]['title']}</em></li>');
{/loop}
{loop $pinfo $p}
document.write('<a href="{$p['setting'][1]['linkurl']}" target="_blank" title="{$p['setting'][1]['alt']}"><img src="{$p['setting'][1]['imageurl']}" alt="{$p['setting'][1]['alt']}"
height="{$height}" width="{$width}"/></a>');
{/loop}
六、基础语法:
定义变量 {php $num=0}
* 注意有些变量是系统自定义的,例如:$catid 、$CATEGORYS 、$parentid 等。
判断 {if $num==0}
双分支判断 {if $num==0} {else} {/if}
结合变量来控制列表生成数量:
{php $num=0}
{pc:content action="lists" catid="67" num="30" order="listorder , id DESC" page="$page"}
{loop $data $r}
{php $num++}
<li> <a href="{$r[url]}" target="_blank">{$r{title}}</a></li>
{if $num%5==0}<hr />{/if}
{/loop}
{/pc}
七、实例与技巧:
#1 loop中拿到文章的属性:
{pc:content action="position" posid="14" order="listorder DESC,id DESC" num="5"}
{loop $data $r}
$r[catid] //当前文章所属栏目id
$r[catdir] // 当前文章所属栏目英文名称
$r[catname] //当前文章所属栏目中文名称
{/loop}
{/pc}
#2 PC标签的三种用处:
循环列表:
{pc:content action="lists" catid = }
循环推荐位
{pc:content action="position" posid = }
循环栏目:
{pc:content action="category" catid=}
#3 根据栏目名称获得栏目ID
<?php
$result = array();
$catList = array();
foreach ($CATEGORYS as $key=>$val) {
foreach ($val as $key1=>$val1) {
if($key1 == 'catdir'){
$result[$key] = $val[$key1];
}
}
}
foreach ($result as $a=>$val){
$catList[$val] = (String)$a;
}
?>
//调用方法:$catList['categoryName']
#4 CATEGORYS数组实例使用
* explode -- 将字符串转换为数组
* empty -- 判断是否为空
* array_keys -- 以参数数组的“键”组成一个新的数组返回。
* end -- 返回数组最后一个数组元素。
<ul class="clearfix gamedata-list">
<?php
$strchildid = $CATEGORYS[$catid]['arrchildid'];
$arrchildid = explode(',',$strchildid);
if(!empty($arrchildid)){
foreach($arrchildid as $v){
if($v == $catid) {
countinue;//过滤自己
}else if($CATEGORYS[$v]['parentid'] != $catid){
countinue;//过滤非直接子类
}else{
?>
<li class="tit newplayer nl_{$CATEGORYS[$v]['catdir']}"><span></span>{$CATEGORYS[$v]['catname']}</li>
<li class="main-text">
<?php
$strchildid2 = $CATEGORYS[$v]['arrchildid'];
$arrchildid2 = explode(',',$strchildid2);
if(!empty($arrchildid2)){
foreach($arrchildid2 as $v2){
if($v2 == $v) {
countinue;//过滤自己
}else{
?>
<dl>
<dt><span></span>{$CATEGORYS[$v2]['catname']}:</dt>
<dd>
{pc:content action="lists" catid="$v2" num="20" order="listorder DESC,id DESC"}
{php $e= end(array_keys($data))}
{loop $data $key $r}
<a href="{$r[url]}" target="_blank">{$r[title]}</a>
{if $key != $e}
<span>|</span>
{/if}
{/loop}
{/pc}
</dd>
</dl>
<?php
}
}
}
}
}
}
?>
</li>
</ul>
#5 pc标签使用示例
<div class="gamedata-content">
{pc:content action="category" catid="$catList['gamedata']" order="listorder DESC" num ="100" }
{loop $data $r}
<h3 class="gamedata-title">{$r[catname]}</h3>
<ul class="gamedata-content-list">
{pc:content action="category" catid="$r[catid]" order="listorder DESC" num="500" }
{loop $data $s}
<li>
<dl class="clearfix">
<dt>{$s[catname]}<i></i></dt>
<dd>
{pc:content action="lists" catid="$s[catid]" num="1000" order="listorder,id DESC"}
{php $e= end(array_keys($data))}
{loop $data $key $v}
<a href="{$v[url]}" target="_blank">{$v[title]}</a>
{if $key != $e}
<span>|</span>
{/if}
{/loop}
{/pc}
</dd>
</dl>
</li>
{/loop}
{/pc}
{/loop}
{/pc}
</div>
八、CATEGORYS 常用命令:
$CATEGORYS(栏目命令) 标签
$CATEGORYS是一个二维数组,它用于保存当前栏目的相关信息。
$CATEGORYS[65][catname]返回指定栏目的栏目名称
$CATEGORYS[$catid][catid] 栏目ID
$CATEGORYS[$catid][module] 栏目所在的模块
$CATEGORYS[$catid][type] 栏目类型
$CATEGORYS[$catid][modelid] 栏目所属模型id
$CATEGORYS[$catid][catname] 栏目名称
$CATEGORYS[$catid][style] 栏目名称样式
$CATEGORYS[$catid][image] 栏目图片
$CATEGORYS[$catid][catdir] 栏目路径
$CATEGORYS[$catid][url] 目录url
$CATEGORYS[$catid][parentid] 栏目的父id
$CATEGORYS[$catid][arrparentid] 所有上级栏目ID
$CATEGORYS[$catid][parentdir] 父栏目的路径
$CATEGORYS[$catid][child] 是否有子栏目
$CATEGORYS[$catid][arrchildid] 栏目的所有子栏目id
$CATEGORYS[$catid][items] 栏目信息数
$CATEGORYS[$catid][ismenu] 栏目是否显示导航
{$CATEGORYS[$catid][description]} 栏目描述
{$CATEGORYS[$catid][hits]} 栏目点击数
{$CATEGORYS[$parentid][catid]} 父栏目ID
{$CATEGORYS[$parentid][catname]} 父栏目名称
{$CATEGORYS[$top_parentid][catid]} 顶级栏目ID
{$CATEGORYS[$CATEGORYS[$CAT[parentid]][parentid]][catname]} 上上级栏目名称
{$CATEGORYS[$CATEGORYS[$CAT[parentid]][parentid]][url]} 上上级栏目链接