1. 程式人生 > >dede5.7欄目新增上縮圖功能

dede5.7欄目新增上縮圖功能

當我們一個欄目列表都用縮圖來表示產,而不僅僅只是文字,如果沒有這項功能會非常麻煩,網上有很多這方面的資料,但是都試過了有很多問題,自己研究一下,測試基本通過。需要新加欄位 typeimg
後臺執行SQL:
 

  1. alter table `80php_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 `80php_arctype`

 

  1. (reid,topid,sortrank,typename,typedir,

替換為

 

  1. (reid,topid,sortrank,typename,typedir,typeimg,

 

  1. ('~reid~','~topid~','~rank~','~typename~','~typedir~',

替換為

 

  1. ('~reid~','~topid~','~rank~','~typename~','~typedir~','~typeimg~',

開啟dede/catalog_edit.php
查詢

 

  1. $upquery = "Update `80php_arctype` set

 

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


開啟dede/templets/catalog_add.htm
查詢

 

  1.           <tr>
  2.             <td height="26">列表命名規則:</td>
  3.             <td>
  4.               <input name="namerule2" type="text" id="namerule2" value="{typedir}/list_{tid}_{page}.html"  class="pubinputs"  style="width:250px" />
  5.               <img src="img/help.gif" alt="幫助" width="16" height="16" border="0" style="cursor:pointer" onClick="ShowHide('helpvar3')"/></td>
  6.           </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>
說明:下面這句會調用出已新增的路片路徑。
<?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呼叫就可以了。