• 全国400电话网上服务平台
    强大号码库资源任选,方便,快捷,快速开通。
    咨询热线:400-1100-266  

    织梦dedecms栏目添加自定义字段,增加栏目上传缩
    POST TIME:2020-04-02 13:54

    我们用织梦制作企业网站时,点击进入每个栏目时,都会有“关于我们”,“新闻中心”,“产品展示”等提示性的图片,单独调用这些图片比较麻烦,我们可以修改程序,实现每个栏目都有上传栏目缩略图的功能,就方便多了。

    修改方法如下:

    第一步:执行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

    查找

    <tr>
    <td height="26">列表命名规则:</td>
    <td>
    <input name="namerule2" type="text" id="namerule2" value="{typedir}/list_{tid}_{page}.html" class="pubinputs" style="width:250px" />
    <img src="img/help.gif" alt="帮助" width="16" height="16" border="0" style="cursor:pointer" onClick="ShowHide('helpvar3')"/></td>
    </tr>

    在其下面增加以下内容

    <tr>
    <td height="65" style="padding-left:10px;">栏目图片:</td>
    <td>
    <input name="typeimg" type="text" style="width:250px" id="typeimg" class="alltxt" value="" />
    <input type="button" name="set9" value="浏览... "class="coolbg np" style="width:60px" onClick="SelectImage('form1.typeimg','');" />
    </td>
    </tr>

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

    <script language='javascript' src="js/main.js"></script>

    4、打开dede/templets/catalog_edit.htm

    在刚前面的位置加入:

    <tr>
    <td height="65" style="padding-left:10px;">栏目图片:</td>
    <td>
    <input name="typeimg" type="text" style="width:250px" id="typeimg" class="alltxt" value="<?php echo $myrow['typeimg']?>" />
    <input type="button" name="set9" value="浏览... "class="coolbg np" style="width:60px" onClick="SelectImage('form1.typeimg','');" />
    </td>
    </tr>

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

    <?php echo $myrow['typeimg']?>

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

    <script language='javascript' src="js/main.js"></script>

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

    原来是这样的:

    {dede:channel type='top' row='13'}
    <li><a href='[field:typeurl/]' [field:rel/]>[field:typeimg/]</a></li>
    {/dede:channel}

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

    {dede:sql sql="SELECT typename,typedir,typeimg FROM dede_arctype"}
    <li><a href="[field:typedir/]">[field:typeimg/]</a></li>
    {/dede:sql}

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

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

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

    打开includerc.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);

    即可。

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

    
    关于我们 | 付款方式 | 建站知识 | 增值服务 | 网站模板
    Copyright © 2003-2016
    时间:9:00-21:00 (节假日不休)
    版权所有:巨人网络(扬州)科技有限公司
    总部地址:江苏省信息产业基地11号楼四层
    《增值电信业务经营许可证》 苏B2-20120278
    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信

    微信号已复制,请打开微信添加咨询详情!