网站模板中心

您现在的位置:首页>>织梦大学>>辅助文档

dede模板栏目添加自定义字段,增加栏目上传缩略

来源: 编辑:admin 发布时间:2020-03-12热度:59 ℃
我们用织梦s制作企业网站时,点击进入每个栏目时,都会有关于我们,新闻中心,产品展示等提示性的图片, 单独调用这些图片比较麻烦,我们可以修改程序,实现每个栏目都有上...
我们用织梦dedecms制作企业网站时,点击进入每个栏目时,都会有“关于我们”,“新闻中心”,“产品展示”等提示性的图片,

单独调用这些图片比较麻烦,我们可以修改程序,实现每个栏目都有上传栏目缩略图的功能,就方便多了。

 
修改方法如下:
第一步:执行SQL命令为数据库的栏目表结构添加一个字段
alter table `dede_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
1、打开dede/catalog_add.php
查找
$queryTemplate = "insert into `dede_arctype`
(reid,topid,sortrank,typename,typedir,
替换为
(reid,topid,sortrank,typename,typedir,typeimg,
('~reid~','~topid~','~rank~','~typename~','~typedir~',
替换为
('~reid~','~topid~','~rank~','~typename~','~typedir~','~typeimg~',
2、打开dede/catalog_edit.php
查找
$upquery = "Update `dede_arctype` set
在其下面新加一行
`typeimg`='$typeimg',
3、打开dede/templets/catalog_add.htm
查找
列表命名规则: 帮助

在其下面增加以下内容
栏目图片:

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

4、打开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调用就可以了。
    添加或修改图片时在《栏目管理》高级选项
    如果想同时在文章内容页调用
    打开includearc.archives.class.php
    查找
    if($this->ChannelUnit->ChannelInfos['issystem']!=-1)

    $query = "Select arc.*,tp.reid,tp.typedir,ch.addtable
                     from `ant_archives` arc
                              left join ant_arctype tp on tp.id=arc.typeid
                               left join ant_channeltype as ch on arc.channel = ch.id
                               where arc.id='$aid' ";
                     $this->Fields = $this->dsql->GetOne($query);

    替换为
    $query = "Select arc.*,tp.reid,tp.typedir,tp.typeimg,ch.addtable
                     from `ant_archives` arc
                              left join ant_arctype tp on tp.id=arc.typeid
                               left join ant_channeltype as ch on arc.channel = ch.id
                               where arc.id='$aid' ";
                     $this->Fields = $this->dsql->GetOne($query);

    即可。
    需要这个功能的朋友,去试试吧。

    Pbootcms问题解决

    请点击在线联系我们【点击咨询解决问题】   如果您有任何Pbootcms问题,我们将免费为您写解决教程!

      PB模板网:承接仿站业务,价格200元起!