织梦DedeCMS的栏目调用仅仅只有文字调用,没有栏目缩略图调用,而我们有时候又需要给栏目添加缩略图,并能够在前台调用,就可以试试通过下面的方法,给栏目添加缩略图。
首先要给栏目数据库表添加一个存储缩略图的字段,我们将该字段命名为typeimg,可以通过后台执行sql命令行来添加,具体sql命令如下:
alter table `dede_arctype` add `typeimg` char(100) NOT NULL default '';
|
里面的dede自行替换为自己的数据库前缀,执行完成后还需要修改下面几个文件,分别是
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
查找
<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>
打开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>
并在文件的head增加以下内容
<script language='javascript' src="js/main.js"></script>
到这里就添加完成了,但是在模板里面直接用{dede:field.typeimg /} 是调不出数据的,需要用SQL调用。
具体sql语句如下:
{dede:sql sql="SELECT typename,typedir,typeimg FROM dede_arctype"}
<li><a rel="nofollow noopener noreferrer" href="[field:typedir/]">[field:typeimg/]</a></li>
{/dede:sql}
这样就顺利的调出来了,当然如果你要调用子ID的话,只要加上相应的条件ID调用就可以了。
|