AutoCAD 3DMAX C语言 Pro/E UG JAVA编程 PHP编程 Maya动画 Matlab应用 Android
Photoshop Word Excel flash VB编程 VC编程 Coreldraw SolidWorks A Designer Unity3D
 首页 > PHP编程

PHPCMS教程_标签调用代码详解

51自学网 2016-09-26 http://www.wanshiok.com
一。模板制作之标签篇

1. 内容标签
在官方模板页里边,我们可以看到如 {tag_网站首页头条} 这样的标签。
这种标签就是“内容标签”,可以在后台的“模板风格”->的“内容标签管理”里进行查看和修改。
这种标签属于模块化的标签,也就是说它通过SQL语句查询配合数据调用条件赋值到模板通过模板
引擎来进行读取和生成的。 大家编辑一下模板基本上就能看出来。 【如果打算做出一个个性化的网站,
我不太推崇过多的使用这种方式,当然,很多重复调用的部分,用这种方式还是不错的。
或许是因为个人喜好,我个人不太常用这种方式,所以这里就不多讲,我们
今天主要要讲一下get
2. get常用调用方式
我觉得这种方式的灵活性很强大。个人推荐。下面将重点说一下,get的几种常用调用方式,个人认为,
做PHPCMS的模板,了解了get基本上就够用了。
(1)调用一个栏目下的最新,带缩略图的文章,同时调用出起内容简介(多个栏目ID调用)
以下为模板中的标签:

<div class="oz_z1" id="tt_index"><!--中一开始资讯推荐-->
{get sql="select*from content where catid>=79 and catid<=85 and status=99 and posids=1
and `thumb`!='' order by updatetime desc" rows="1"}
<li><A href="{$r[url]}" target="_blank">{str_cut($r[title], 40)}</A></li><br />
<div id="tit_z1">
<dt><A href="{$r[url]}" title="{str_cut($r[title], 50)}" target="_blank"><img
src="{thumb($r[thumb], 110, 75)}" /></A></dt>
<dl><A href="{$r[url]}" target="_blank">{str_cut($r[description],100)}</A></dl>
</div>
{/get}
在使用get的时候注意一点就是{/get} get的结束标签。
说明: content 这是数据库里边数据表的名称,如果你的数据表前缀进行了修改,这里也必须进行修改。
如果你在安装phpcms的时候设置的为woshi_. 那么这里就应该是woshi_content
catid>=79 and catid<=85 栏目ID大于等于75并且栏目id小于等于85. 也就是调用
栏目ID75 76 77 78 79 80 81 82 83 84 85的文章。
posids=1 文章类型为首页推荐
status=99 文章已经通过审核
`thumb`!='' 缩略图不为空,也就是必须要有缩略图
{$r[url]} 内容页的地址
{str_cut($r[title], 40)} 文章标题,长度限制为40
{thumb($r[thumb], 110, 75)} 缩略图地址 缩略图大小限制为width=110px height=75px
{str_cut($r[description],100) 文章简介调用 简介长度为100
通过上面的调用及模板语句(div li ),我通过css的控制可得出如下test.gif。 具体的css部分,
我们后面在讲。
(2)调用多个栏目ID,(栏目ID为不连续ID) 也就是说我们在栏目建立初期
有栏目ID75 76 77 78 79 80 81 82 83 84 85。 而在建立了其它栏目之后,我们有在这个栏目添加了一个新的栏目,产生了一个新的ID。
比如ID 95.那么我们应该怎么样使用get来调用啦?
在(1)中我们使用了catid>=XX and catid<=XX 如果说现在要加入catid95 那么就不能在用and了
而应该使用 or 。 具体方式如下
{get sql="select*from content where catid>=79 and catid<=85 or catid=95 order by updatetime desc" rows="6"}
{/get}
如果说我们这里调用的是文章标题列表 数量为6 那么我们要在div中循环的就应该是li了。具体如下
<div class="oz_z2">
{get sql="select*from content where catid>=79 and catid<=85 or catid=95 order by updatetime desc" rows="6"}
<li><A href="{$r[url]}" target="_blank">{str_cut($r[title], 38)}</A></li>
{/get}
</div>
这里说明一点updatetime 的排序方式。 比如说我们想按照文章录入的时间来进行降序排列(也就是吧最新的排前面),
在使用updatetime之后,我们会发现,编辑一前的文章之后,这篇文章被调用到了列表的最前面。
所以updatetime是文章编辑或修改时间,如果我们不想以这种方式进行排序,而是想以文章录入时间进行降序排列,
可以吧这里的updatetime改为inputtime(3)使用get调用 栏目名及其相对应的栏目地址
在使用get的sql查询时,我们通常都会查询content这个表,在这个表里边包括了所有的文章及下载等内容信息,
但栏目只有id却没有栏目名,所有的栏目信息都在category这个表里边,其实打开数据库一看,我们就一目了然了。
所以在调用栏目名及其地址的时候我们需要借助 {str_cut($CATEGORY[$r[catid]][catname],4)} 这种方式来进行参数传递,
呵呵,我索性连栏目名长度截取也加上,方便大家吧。呵呵。 有够BT ,呵呵 具体示例如下:
<div class="oz_z2">
{get sql="select*from content where catid>=52 and catid<=55 or catid=50 or catid=77 or catid=78
order by updatetime desc" rows="6"}
<li><p>[<a href="{$CATEGORY[$r[catid]][url]}" target="_blank">{str_cut($CATEGORY[$r[catid]][catname],4)}</a>]</p>
<A href="{$r[url]}" target="_blank">{str_cut($r[title], 38)}</A></li>
{/get}
</div>
这个get调用的栏目ID分别为52 53 54 55 77 78 活学活用 呵呵!
{$CATEGORY[$r[catid]][url]} 栏目地址
{str_cut($CATEGORY[$r[catid]][catname],4)} 栏目名 长度为4 根据自己需要调整吧~
其他参数前面介绍了! 这里就不多说了  继续下一个问题。
(4)如何调用后台设置的标题颜色
其实这个并不神秘。 只是个<span></span>而已! 呵呵 接下来就直接示例吧!
<div id="hdlist">
<ul>
{get sql="select*from 99inet_content where catid=40 and status=99 order by updatetime desc" rows="7"}
<li> [{date('m-d', $r <A href="{$r[url]}" target="_blank">{if $r[style]}
<span class="{$r[style]}"> {str_cut($r[title], 22)}</span>{else}{str_cut($r[title], 22)}{/if}</A></li>
{/get}</ul>
</div>
{get}部分俺就不说了,上面基本上都说了~ [{date('m-d', $r[updatetime])}] 这个地方调用的是文章日期
在这个小部分,大家注意我标出来的蓝色代码和量个绿色代码,有人会问:为什么调用两次标题里??
呵呵 别急 接下来告诉大家为什么。
<A href="{$r[url]}" target="_blank">{if $r[style]}<span class="{$r[style]}">{str_cut($r[title], 22)}</span>{else}{str_cut($r[title], 22)}{/if}</A>
其实这段代码好简单奥,有html基础地人都能看明白。{if$r[style]}
如果数据库相对应的文章的style字段不为空(也就是有内容),就生成
<span class="{$r[style]}">{str_cut($r[title], 22)}</span> ,也就是说如果这篇文章你设置了标题颜色或者效果(加粗、斜体等),
那么最终生成的html页应该是这样的
<a href="文章地址" target="_blank"><span class="b">网站标题</span></a>
其实class的指是官方设置好的,这里的b是标题加粗。 其值我们在这里不深究。
如果说在后台没有给标题加任何效果。你们生成的html就是
<a href="文章地址" target="_blank网站标题</a> 没有调用<span>而已
我尽量说的比较简单了,我认为这个确实应该很简单了吧。 呵呵
忘了一点,不过记得以前有位仁兄好像发过,想象我也加上吧,这样基本上get的常规用法就比较全面了。
(5)调用的技巧,limit参数。 【比如:调用从第二条开始的连续几条信息】
<div id="hdlist">
<ul>
{get sql="select*from content where catid=39 and status=99 order by updatetime desc limit 2,7"}
<li>[{date('m-d', $r[updatetime])}]
<A href="{$r[url]}" title="{str_cut($r[title], 50)}" target="_blank">{if $r[style]}<span class="{$r[style]}">{str_cut($r[title], 22)}
</span>{else}{str_cut($r[title], 22)}{/if}</A>
</li>
{/get}</ul>
</div>
调用栏目id为39并且通过审核的文章,从第二条起的连续7条信息。 这个里边就使用了上面讲的调用后台
设置的标题颜色。简单 简单 相当的简单。 这次真的完了。 奥对了,在使用limit是 不可同时使用row ,
至于为什么?你想想就明白了
(6)如何使用get在栏目首页调用所有文章模型的文章 (这个是模型的全部)
<div class="test">
{get sql="SELECT contentid,catid,typeid,areaid,title,style,thumb,keywords,description,
userid,updatetime,inputtime,url FROM `yimi_content` WHERE status=99 ".get_sql_catid($cid)."
ORDER BY contentid DESC" rows="40"}
<li><a href="{$r[url]}">{$r[title]}</a></li>
{/get}
</div>
可惜是模型的全部 大家可以试验一下 给个思路 研究中...
(7)最近发现一个问题,哪就是在get的使用过程中 大家比较困惑的是id的取值,这点是我没想到的,呵呵,
所以我今天增加了栏目首页调用所有子栏目内容的说明。同时也提一下,id的另一种赋值方法。
{get sql="SELECT * FROM `content` c,`content_count` n WHERE c.contentid=n.contentid
AND c.`status`=99 and catid in (39,40,41,42,43,44,45,46,47,48,66,68,69,70,71,72,73,74,75,76)
ORDER BY contentid DESC" rows="10"}
<li><a href="{$r[url]}">{$r[title]}</a></li>
{/get}
用哪种方法就看自己喜好吧,反正个人认为能达到目的就行。
注意在(6)和(7)中的 `content` 这个符号是``而不是'' 搞错了没办法执行。


说明
:本教程来源互联网或网友上传或出版商,仅为学习研究或媒体推广,wanshiok.com不保证资料的完整性。
 
上一篇:PHPCMS V9 核心文件说明  下一篇:完美解决phpcms v9忘记后台密码的方法