在使用PC v9建站过程中,一般站长会精益求精,在数据调用方面会一试再试,做到尽善尽美,这不,一个朋友Whidy就连夜研究了PHPCMS专题总列表页内的某个专题含有该专题的几篇文章的方式,下面CMSYOU来与大家具体分享,原地址为http://whidy.net/phpcms-speciallist-with-subarticle-loop.html,在这里感谢。
好吧,由于工作需求,外加自己过分追求完美,晚上研究了一下,PHPCMS专题总列表页内的某个专题含有该专题的几篇文章的方式,其实原理很简单,核心思想是
1.嵌套循环.
2.数据库中存储总列表内某专题的id值等于该专题某文章列表的id值.
———————————————————————————————————————————-
昨晚其实最后效果还有点问题,今天上午一上班继续解决,终于弄好了,现在跟大家分享心得.
前文可能这样说大家看不大明白,我先截取两张图片给大家看:
想实现的效果:通俗点讲就是假设你后台有5个专题,而且这5个专题内有若干篇相关文章,你希望这个专题列表页面不单单显示出这5个专题信息,在列表中每个单独的专题区域能够显示该专题下的文章.
实现原理:很显然从逻辑上来讲就是一个嵌套循环,大循环,循环的是有多少个专题,挨个输出,而在每个已经输出的专题中,再次运行一次小循环,来循环当前专题内的所有文章.
准备工作:当然理解了原理,有了思想之后,就好办了,先看看PHPCMS V9专题管理的数据库表.这里有两个表”v9_special“和”v9_special_content“,一看就知道了,前者是管理有多少个专题的,后者是存放这些专题的所有内容的.而两个表如何关联起来,由于我数据库和php学的都不好(大家都知道我之前做网页设计和前端的–!),所以代码也许略有不合理的地方.我之前尝试用系统默认的PC标签”pc:special“来写,但是未能实现,于是只好用我认为最暴力的方式,直接读取数据库的”pc:get sql=’ ‘“,接着观察两个表的字段.他们功能连接的方式是v9_special的id和v9_special_content的specialid.那么再循环过程中将这两个值关联起来就可以了.
实现方法:由于这个站展示在公司网站上了,所以就不写CSS出来了,大家只需要理解了,可以自己想怎么用就怎么用.我的代码是这样写的:
<div class="hifi_PubArea">
<!--嵌套循环输出专题及专题内文章By小白-->
{pc:get sql="SELECT * FROM v9_special ORDER BY createtime DESC" num="10" return="data"}
<ul class="hifi_ListPage_MainList">
{loop $data $r}
{php $sid=$r['id']}
<li>
<div class="Title">
<div class="LeftTitle">{if time()-$r['createtime'] <= 24*3600}<img src="{IMG_PATH}hifidiy/hifi010.gif" />{else}{/if}<a href="{$r['url']}">{$r['title']}</a><span>[<a href="{$CATEGORYS[$catid]['url']}">{$catname}</a>]</span></div>
<div class="RightTitle"> <span class="author">{if $r['username']}{$r['username']}{else}hifidiy{/if}</span> </div>
</div>
<div class="Content">
<div class="DivImg"><a href="{$r['url']}"><img src="{thumb($r['thumb'],165,95)}" alt="{$r['thumb']}" /></a></div>
<div class="DivContent">{str_cut($r['description'],240)}[<a href="{$r['url']}">查看</a>]
<div class="subArticle">
{pc:get sql="SELECT * FROM v9_special_content WHERE specialid = '$sid' ORDER BY updatetime ASC" num="4" return="data"}
<ul>
{loop $data $t}
<li><a href="{$t['url']}">{$t['title']}</a></li>
{/loop}
</ul>
{/pc}
</div>
</div>
</div>
</li>
{/loop}
<div class="bk"></div>
</ul>
<div id="pages">{$pages}</div>
{/pc}
</div>
关键部位我已经做了高亮,方便大家查看.我顺便简单讲解一下, 第一行高亮表示从v9_special表获取所有字段内容,当然里面有个id字段的所有值也获取了,接下来将这个值赋值给sid,那么在第一个循环内,$sid==id,并继续执行下个循环(第二条高亮部分),从v9_special_content内获取所有字段的内容,当然这里加了个条件因为这个表内包含了不止一个专题的文章,因此我将条件设定为specialid==$sid,这样就不会出现文章调用问题了.至于数量顺序什么的就很简单了,这里不再熬述.
好了,其实写完这篇文章想想,好像很简单的一个自定义功能,但是为什么昨天晚上做了半天效果出不来呢,呵呵,还是编程语言基础不扎实,还得努力啊!
在此感谢Whidy的详细讲解! 如果有不明了的需要探讨,欢迎联系CMSYOU!
点击加载更多