自带完整数据 快速建站好帮手
客服QQ客服QQ 客服微信客服微信 公众号公众号

phpcmsV9想要调用全站最新文章怎么二次开发

本文介绍了phpcmsV9想要调用全站最新文章怎么二次开发,用过PHPCMS的朋友都知道,因为PHPCMS使用了模型的方式,导致默认的调用是以模型或频道的形式进行的,默认是没法进行全站文章的调用,这个教程就告诉大家怎么实现全站最新文章的调用。

下面就由瓦窑源码和大家说下phpcmsV9调用全站最新文章二次开发的方法。

实现教程:

打开 \phpcms\modules\content\classes\content_tag.class.php,找到以下函数:

/** 
      * 列表页标签 
      * @param $data 
      */ 
     public function lists($data) { 
         $catid = intval($data['catid']); 
         if(!$this->set_modelid($catid)) return false; 
         if(isset($data['where'])) { 
             $sql = $data['where']; 
         } else { 
             $thumb = intval($data['thumb']) ? " AND thumb != ''" : ''; 
             if($this->category[$catid]['child']) { 
                 $catids_str = $this->category[$catid]['arrchildid']; 
                 $pos = strpos($catids_str,',')+1; 
                 $catids_str = substr($catids_str, $pos); 
                 $sql = "status=99 AND catid IN ($catids_str)".$thumb; 
             } else { 
                 $sql = "status=99 AND catid='$catid'".$thumb; 
             } 
         } 
         $order = $data['order']; 
  
         $return = $this->db->select($sql, '*', $data['limit'], $order, '', 'id'); 
                          
         //调用副表的数据 
         if (isset($data['moreinfo']) && intval($data['moreinfo']) == 1) { 
             $ids = array(); 
             foreach ($return as $v) { 
                 if (isset($v['id']) && !emptyempty($v['id'])) { 
                     $ids[] = $v['id']; 
                 } else { 
                     continue; 
                 } 
             } 
             if (!emptyempty($ids)) { 
                 $this->db->table_name = $this->db->table_name.'_data'; 
                 $ids = implode('\',\'', $ids); 
                 $r = $this->db->select("`id` IN ('$ids')", '*', '', '', '', 'id'); 
                 if (!emptyempty($r)) { 
                     foreach ($r as $k=>$v) { 
                         if (isset($return[$k])) $return[$k] = array_merge($v, $return[$k]); 
                     } 
                 } 
             } 
         } 
         return $return; 
     } 

修改为:

/** 
      * 列表页标签 
      * @param $data 
      */ 
     public function lists($data) { 
         $catid = intval($data['catid']); 
          
         if(isset($data['where'])) { 
             $sql = $data['where']; 
         } else { 
             $thumb = intval($data['thumb']) ? " AND thumb != ''" : ''; 
             if(!emptyempty($catid)) { 
                 if(!$this->set_modelid($catid)) return false; 
                 if($this->category[$catid]['child']) { 
                     $catids_str = $this->category[$catid]['arrchildid']; 
                     $pos = strpos($catids_str,',')+1; 
                     $catids_str = substr($catids_str, $pos); 
                     $sql = "status=99 AND catid IN ($catids_str)".$thumb; 
                 } else { 
                     $sql = "status=99 AND catid='$catid'".$thumb; 
                 } 
             } 
             else { 
                 $sql = "status=99".$thumb; 
             } 
                  
         } 
         $order = $data['order']; 
  
         $return = $this->db->select($sql, '*', $data['limit'], $order, '', 'id'); 
                          
         //调用副表的数据 
         if (isset($data['moreinfo']) && intval($data['moreinfo']) == 1) { 
             $ids = array(); 
             foreach ($return as $v) { 
                 if (isset($v['id']) && !emptyempty($v['id'])) { 
                     $ids[] = $v['id']; 
                 } else { 
                     continue; 
                 } 
             } 
             if (!emptyempty($ids)) { 
                 $this->db->table_name = $this->db->table_name.'_data'; 
                 $ids = implode('\',\'', $ids); 
                 $r = $this->db->select("`id` IN ('$ids')", '*', '', '', '', 'id'); 
                 if (!emptyempty($r)) { 
                     foreach ($r as $k=>$v) { 
                         if (isset($return[$k])) $return[$k] = array_merge($v, $return[$k]); 
                     } 
                 } 
             } 
         } 
         return $return; 
     } 

前端调用代码:

{pc:content action="lists" num="10" order="id DESC" cache="3600"}

这样就可以实现全站最新文章调用了,有需要的可以试试看,是不是有很有效呢。

TAG标签:phpcms全站最新文章

上一个:phpcmsV9想要在模板上面使用碎片功能怎么开发
下一个:phpcmsV9前端想在获取随机文章怎么开发

织梦网站源码

咨询客服

QQ:1847629575

全年 09:00-23:00

(其他时间请留言)

在线客服

Copyright©2021 www.why114.com 瓦窑源码 版权所有 鲁ICP备20017802号

展开