dede5.7 给栏目添加上缩略图

如我们一个栏目列表都用缩略图来表示,而不仅仅只是文字,如果没有这项功能会非常麻烦,网上有很多这方面的资料,但是都试过了有很多问题,自己研究一下,测试基本通过。新加字段 typeimg
后台执行SQL:

alter table `cn_arctype` add `typeimg` char(100) NOT NULL default '';
涉及到文件:

dede/catalog_add.php
dede/catalog_edit.php
dede/templets/catalog_add.htm
dede/templets/catalog_edit.htm

打开dede/catalog_add.php
查找$queryTemplate = "insert into `cn_arctype`

(reid,topid,sortrank,typename,typedir,
替换为
(reid,topid,sortrank,typename,typedir,typeimg,

('~reid~','~topid~','~rank~','~typename~','~typedir~',
替换为
('~reid~','~topid~','~rank~','~typename~','~typedir~','~typeimg~',
打开dede/catalog_edit.php
查找
$upquery = "Update `cn_arctype` set


在其下面新加一行
`typeimg`='$typeimg',


打开dede/templets/catalog_add.htm
查找

列表命名规则:


帮助


在其下面增加以下内容


栏目图片:





并在文件的head增加以下内容


打开dede/templets/catalog_edit.htm
在刚前面的位置加入:

栏目图片:





说明:下面这句会调用出已添加的路片路径。


并在文件的head增加以下内容


我试了一下在模版里用:{dede:field.typeimg /} 是调不出数据的,所以我改成了SQL调用。
原来是这样的:
{dede:channel type='top' row='13'}

  • [field:typeimg/]

  • {/dede:channel}
    在这里面加上[field:typeimg]是调不出来的,我个人认为栏目缩略图就是通过循环出来的,而循环不出来则意义不大,所以改成了如下:
    {dede:sql sql="SELECT typename,typedir,typeimg FROM dede_arctype"}
  • [field:typeimg/]

  • {/dede:sql}
    这样就顺利的调出来了,当然如果你要调用子ID的话,只要加上相应的条件ID调用就可以了。

    {dede:channelartlist typeid='13,14' row ='10'}
    {dede:field name='typename'/}
      {dede:channel type='son' noself='yes' }
      • [field:typename/]
      {/dede:channel}
      {/dede:channelartlist}