600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > 织梦DedeCMS栏目添加自定义字段 增加栏目上传缩略图功能

织梦DedeCMS栏目添加自定义字段 增加栏目上传缩略图功能

时间:2018-09-23 22:09:09

相关推荐

织梦DedeCMS栏目添加自定义字段 增加栏目上传缩略图功能

用织梦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

在刚前面的位置加入:

栏目图片:<input name="typeimg" type="text" value=""/>

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

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

在模版里用:{dede:field.typeimg /} 是调不出数据的,所以改成SQL调用。

原来是这样的:

{dede:channel type= op row=13}

[field:typeimg/] {/dede:channel}

在这里面加上[field:typeimg]是调不出来的,栏目缩略图就是通过循环出来的,而循环不出来则意义不大,所以改成了如下:

{dede:sql sql="SELECT typename,typedir,typeimg FROM dede_arctype"}

[field:typeimg/]{/dede:sql}

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

添加或修改图片时在《栏目管理》高级选项

如果想同时在文章内容页调用

打开\include\arc.archives.class.php

查找

if($this->ChannelUnit->ChannelInfos[issystem]!=-1)

$query = "Select arc.*,tp.reid,tp.typedir,ch.addtable from `ant_archives` arcleft 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` arcleft 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);

即可。

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。