dedecms专题文章列表的模板修改

2019-10-24,,

如果没有进行特别的设置,专题的文章列表显示默认是采用的default下面的article_spec.htm文件作为模板。
这个模板文件很简单,前面是该专题的一些信息,下面是分割线,分割线以下就是现实节点和节点文章的模块。
这个模块按理说应该是专题模板最重要的内容,可是只有下面几行:
<div class="speciallist">
  {dede:field.note/}
</div>
实在是让人出乎意料-这让人怎么改啊,连html标签都看不到。虽然不满,但是既然用了dedecms,就只能这样了,也许作者是希望减少用户的工作量吧,可以理解。
 
要灵活的修改这个页面显示节点文章的样式,我想到了两种办法:

  • 直接在浏览器显示该页面时查看html代码的方式。
  • 不管你后台是如何做的,显示在浏览器上的才是最终结果。所以我只需看你最终的html代码,查看用到了那些html元素,在将相关元素的css写在样式表里面。这里有点小技巧,用firefox的firebug可以很容易的完成这个工作,至于怎么用,这里就不讲解了,可以直接百度。
     
                                <dl class="tbox">
                                         <dt><strong>节点名称</strong></dt>
                                         <dd>
                                                   <ul class="d1 ico3">
                                 节点文章列表
                                                   </ul>
                                         </dd>
                                </dl>
    知道这个以后,修改样式应该不难了吧。
     

  • 虽然上诉的方法不麻烦,但是总觉得不灵活。那我们直接看源码,然后随意的修改吧。
  • 处理专题主题调用标签{dede:field.note/}的php文件是include/taglib/channel/specialtopic.lib.php.
     
    找到ch_specialtopic()函数的第五行
    $tempStr = GetSysTemplets('channel_spec_note.htm');
    从这里可以看到channel_spec_note.htm这个文件决定了节点和节点文章的显示。
    channel_spec_note.htm文件放在系统模板文件里面templets/system/channel_spec_note.htm
    打开该文件我们发现里面的html代码和在浏览器查看的几乎一模一样:
                           <dl class="tbox">
                                         <dt><strong>~notename~</strong></dt>
                                         <dd>
                                                   <ul class="d1 ico3">
                                 ~spec_arclist~
                                                   </ul>
                                         </dd>
                                </dl>
     
    在实际运行的时候notename会被替换成节点名,~spec_arclist~
    会被替换成节点文章超链接。~spec_arclist~其实是一个字符串:形如<li>文章超链接</li>
    找到这个文件可以修改除了li之外的所以html元素,但是li我们还是不能为其加上类和id。
    这个应该是在处理的php代码里面。未完待续。。。

    《dedecms专题文章列表的模板修改.doc》

    下载本文的Word格式文档,以方便收藏与打印。