首页 > CMS > PhpCMS > 正文

【phpcms-v9】利用[后台]->[类别管理]为文章前后台添加类别名

2024-09-10 07:15:47
字体:
来源:转载
供稿:网友

【phpcms-v9】利用[后台]->[类别管理]为文章前后台添加类别名称.

1.给专题添加文章时,可以选择类别:

2.给文章模型、图片模型、下载模型的栏目下添加文章内容时,默认不能选择类别:

3.文章模型、图片模型、下载模型的栏目下添加文章内容时,能不能像专题一样可以选择类别?

4.如,要完成如下功能:在PHPCMS的文章管理列表,要实现在文章标题前显示文章类别,这样就可以直接在文章列表里看到类别,不需要点击进入编辑页面才可以看到:

完成方法:打开 phpcms/modules/content/templates/content_list.tpl.php 文件,找到:

  1. <td>   
  2.         <?php   
  3.         if($status==99) {   
  4.             if($r['islink']) {   
  5.                 echo '<a href="'.$r['url'].'" target="_blank">';   
  6.             } elseif(strpos($r['url'],'http://')!==false) {   
  7.                 echo '<a href="'.$r['url'].'" target="_blank">';   
  8.             } else {   
  9.                 echo '<a href="'.$release_siteurl.$r['url'].'" target="_blank">';   
  10.             }   
  11.         } else {   
  12.             echo '<a href="javascript:;" onclick=/'window.open("?m=content&c=content&a=public_preview&steps='.$steps.'&catid='.$catid.'&id='.$r['id'].'","manage")/'>';   
  13.         }?><span<?php echo title_style($r['style'])?>><?php echo $r['title'];?></span></a> <?php if($r['thumb']!='') {echo '<img src="'.IMG_PATH.'icon/small_img.gif" title="'.L('thumb').'">'; } if($r['posids']) {echo '<img src="'.IMG_PATH.'icon/small_elite.gif" title="'.L('elite').'">';} if($r['islink']) {echo ' <img src="'.IMG_PATH.'icon/link.png" title="'.L('islink_url').'">';}?></td>   
  14.         <td align='center' title="<?php echo L('today_hits');?>:<?php echo $hits_r['dayviews'];?>   
  15. <?php echo L('yestoday_hits');?>:<?php echo $hits_r['yestodayviews'];?>   
  16. <?php echo L('week_hits');?>:<?php echo $hits_r['weekviews'];?>   
  17. <?php echo L('month_hits');?>:<?php echo $hits_r['monthviews'];?>"><?php echo $hits_r['views'];?></td>   
  18.         <td align='center'>   
  19.         <?php   
  20.         if($r['sysadd']==0) {   
  21.             echo "<a href='?m=member&c=member&a=memberinfo&username=".urlencode($r['username'])."&pc_hash=".$_SESSION['pc_hash']."' >".$r['username']."</a>";    
  22.             echo '<img src="'.IMG_PATH.'icon/contribute.png" title="'.L('member_contribute').'">';  //开源软件:Vevb.com 
  23.         } else {   
  24.             echo $r['username'];   
  25.         }   
  26.         ?></td> 

 

在其前面添加如下几行代码即可:

  1. <span style="color:#CCC">   
  2. <?php $TYPE = getcache('type_content','commons');?>   
  3. 【<?php echo $TYPE[$r['typeid']]['name'];?>】   
  4. </span> 

 

合并到一块如下:

  1. <td>   
  2.         <span style="color:#CCC">   
  3.         <?php $TYPE = getcache('type_content','commons');?>   
  4.             【<?php echo $TYPE[$r['typeid']]['name'];?>】   
  5.         </span>   
  6.         <?php   
  7.         if($status==99) {   
  8.             if($r['islink']) {   
  9.                 echo '<a href="'.$r['url'].'" target="_blank">';   
  10.             } elseif(strpos($r['url'],'http://')!==false) {   
  11.                 echo '<a href="'.$r['url'].'" target="_blank">';   
  12.             } else {   
  13.                 echo '<a href="'.$release_siteurl.$r['url'].'" target="_blank">';   
  14.             }   
  15.         } else {   
  16.             echo '<a href="javascript:;" onclick=/'window.open("?m=content&c=content&a=public_preview&steps='.$steps.'&catid='.$catid.'&id='.$r['id'].'","manage")/'>';   
  17.         }?><span<?php echo title_style($r['style'])?>><?php echo $r['title'];?></span></a> <?php if($r['thumb']!='') {echo '<img src="'.IMG_PATH.'icon/small_img.gif" title="'.L('thumb').'">'; } if($r['posids']) {echo '<img src="'.IMG_PATH.'icon/small_elite.gif" title="'.L('elite').'">';} if($r['islink']) {echo ' <img src="'.IMG_PATH.'icon/link.png" title="'.L('islink_url').'">';}?></td>   
  18.         <td align='center' title="<?php echo L('today_hits');?>:<?php echo $hits_r['dayviews'];?>   
  19. <?php echo L('yestoday_hits');?>:<?php echo $hits_r['yestodayviews'];?>   
  20. <?php echo L('week_hits');?>:<?php echo $hits_r['weekviews'];?>   
  21. <?php echo L('month_hits');?>:<?php echo $hits_r['monthviews'];?>"><?php echo $hits_r['views'];?></td>   
  22.         <td align='center'>   
  23.         <?php   
  24.         if($r['sysadd']==0) {   
  25.             echo "<a href='?m=member&c=member&a=memberinfo&username=".urlencode($r['username'])."&pc_hash=".$_SESSION['pc_hash']."' >".$r['username']."</a>";    
  26.             echo '<img src="'.IMG_PATH.'icon/contribute.png" title="'.L('member_contribute').'">';   
  27.         } else {   
  28.             echo $r['username'];   
  29.         }   
  30.         ?></td> 

 

5.如何在前台显示类别名称?

如果想在前台显示类别名称也可以通过上述方法来完成,比如:在pc标签中完成类别名称的添加,注明:pc标签调用的都是phpcms/modules/content/libs/classes/content_tag.class文件,文件中的方法对应pc标签中的action属性,如:{pc:content action="lists"}{/pc} 对应文件中 public lists(){//代码}.

第一种方法:在pc标签的lists方法中添加类别名称

  1. /**  
  2.      * 列表页标签:主要返回的是主表中数据与附表中数据  
  3.      * @param $data  
  4.      */   
  5.     public function lists($data) {   
  6.         $catid = intval($data['catid']);                                    //pc标签中catid属性   
  7.         if(!$this->set_modelid($catid)) return false;                        //会根据栏目id->对应的模型id->对应的模型表   
  8.         if(isset($data['where'])) {                                         //如果pc标签中设置了where属性,一般情况下不存在   
  9.             $sql = $data['where'];                                             
  10.         } else {                                                            //如果pc标签中没有设置where属性    
  11.             $thumb = intval($data['thumb']) ? " AND thumb != ''" : '';      //如果有thumb属性   
  12.             if($this->category[$catid]['child']) {                           //当前栏目下是否存在子栏目   
  13.                 $catids_str = $this->category[$catid]['arrchildid'];     //所有子栏目id,包括当前栏目自身id   
  14.                 $pos = strpos($catids_str,',')+1;                             
  15.                 $catids_str = substr($catids_str$pos);                    //所有子栏目id,不包括当前栏目自身id   
  16.                 $sql = "status=99 AND catid IN ($catids_str)".$thumb;       //拼接成一个sql语句   
  17.             } else {   
  18.                     $sql = "status=99 AND catid='$catid'".$thumb;               //如果当前栏目下不存在子栏目   
  19.             }   
  20.         }   
  21.         $order = $data['order'];                                            //pc标签中order属性   
  22.         //$sql作为一个条件出现,调用的是model.calss.php文件中的select方法,返回结果集数组,并按照键名'id'排序   
  23.         $return = $this->db->select($sql'*'$data['limit'], $order'''id');//从数据库中获取主表数据,使用的也是sql语句查询   
  24.     
  25.    
  26.    
  27.    
  28.                  
  29.         //如果需要在前台显示类别名称,可添加如下代码   
  30.         /*  
  31.         $TYPES = getcache('type_content','commons');//获取类别缓存文件,此文件缓存了所有与类别信息相关的信息  
  32.         foreach ($return as $key=>$v) {                                       
  33.             $return[$key][typename]=$TYPES[$v['typeid']][name];//给$return中的每篇文章追加一个类别字段  
  34.         }  
  35.         */   
  36.                 //调用副表的数据   
  37.         if (isset($data['moreinfo']) && intval($data['moreinfo']) == 1) {   //如果pc标签中设置了moreinfo属性:是否调用附表数据   
  38.             $ids = array();   
  39.             //$return为返回的主表数据   
  40.             foreach ($return as $v) {                                       //循环主表中的记录信息:$v-主表中的每条记录   
  41.                 if (isset($v['id']) && !emptyempty($v['id'])) {   
  42.                     $ids[] = $v['id'];                                      //ids[]是主表中排序完成的文章id数组   
  43.                 } else {   
  44.                     continue;   
  45.                 }   
  46.             }   
  47.             if (!emptyempty($ids)) {   
  48.                 $this->db->table_name = $this->db->table_name.'_data';      //副表名    
  49.                 $ids = implode('/',/''$ids);                              //以逗号拼接成一个字符串   
  50.                 $r = $this->db->select("`id` IN ('$ids')"'*''''''''id');//查询与主表中数据有关的副表中的数据   
  51.                 if (!emptyempty($r)) {   
  52.                     foreach ($r as $k=>$v) {                             //副表中的数据   
  53.                         //$return:返回的主表中的数据,主表中的id字段值与附表中的id字段值是对应的,也就是说一篇文章在主表中存储的id跟在附表中存储的id的值是相等的   
  54.                         if (isset($return[$k])) $return[$k] = array_merge($v$return[$k]);//主表中数据与副表中数据合并    
  55.                     }   
  56.                 }   
  57.             }   
  58.         }   
  59.         return $return;   
  60.     }   

 

如果在pc标签的lists方法中添加类别名称,则列表页前台代码应该如下:

  1. <!-- 列表页新闻,每页显示25条新闻 -->   
  2.         {pc:content action="lists" catid="$catid" num="25" order="id DESC" page="$page"}   
  3.         <ul class="list lh24 f14">   
  4. {loop $data $r}   
  5.     <li>   
  6.         <span class="rt">{date('Y-m-d H:i:s',$r[inputtime])}</span>·   
  7.            
  8.         <!--类别名称-->   
  9.         <font color="blue">[$r[typename]]</font>   
  10.  
  11.         <a href="{$r[url]}" target="_blank"{title_style($r[style])}>{$r[title]}</a></li>   
  12.     {if $n%5==0}<li class="bk20 hr">   
  13.         </li>   
  14.         {/if}   
  15. {/loop}   
  16.         </ul>   
  17.         <!-- 分页 -->   
  18.         <div id="pages" class="text-c">{$pages}</div>   
  19. {/pc}   

 

第二种方法:直接在前台代码添加类别名称

如果直接在列表页前台代码中添加类别名称,则代码应该如下:

  1. <!-- 列表页新闻,每页显示25条新闻 -->  
  2.    
  3.         {php $TYPES = getcache('type_content','commons');}   
  4.    
  5.          
  6.         {pc:content action="lists" catid="$catid" num="25" order="id DESC" page="$page"}   
  7.         <ul class="list lh24 f14">   
  8. {loop $data $r}   
  9.     <li><span class="rt">{date('Y-m-d H:i:s',$r[inputtime])}</span><font color="blue">[ {$TYPES[$r[typeid]][name]}]</font>·<a href="{$r[url]}" target="_blank"{title_style($r[style])}>{$r[title]}</a></li>   
  10.     {if $n%5==0}<li class="bk20 hr"></li>{/if}   
  11. {/loop}   
  12.         </ul>   
  13.         <!-- 分页 -->   
  14.         <div id="pages" class="text-c">{$pages}</div>   
  15. {/pc}   

 

效果都如下所示:

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表