• <ul id="cgeq2"></ul>
  • 歡迎您光臨深圳塔燈網(wǎng)絡(luò)科技有限公司!
    電話圖標(biāo) 余先生:13699882642

    網(wǎng)站百科

    為您解碼網(wǎng)站建設(shè)的點點滴滴

    Phpcms V9 調(diào)用全站文章排行的解決方案_PHPCms教程

    發(fā)表日期:2019-12 文章編輯:小燈 瀏覽次數(shù):4256

    今天忙于修改網(wǎng)站界面,想在首頁添加瀏覽排行功能,卻發(fā)現(xiàn)Phpcms竟然不支持調(diào)用全站文章排行。下午仔細研究了Phpcms源碼,終于找到解決辦法。

    默認(rèn)情況下,Phpcms只支持調(diào)用當(dāng)前文章排行,代碼如下:

    {pc:content  action="hits" catid="$catid" num="10" order="views DESC" cache="3600"}

    其中$catid為待調(diào)用欄目的id,如果想實現(xiàn)全站調(diào)用,需要修改phpcms\modules\content\classes\content_tag.class.php文件,找到以下函數(shù):

     
    1.     /** 
    2.  * 排行榜標(biāo)簽 
    3.  * @param $data 
    4.  */ 
    5. public function hits($data) { 
    6.     $catid = intval($data['catid']); 
    7.     if(!$this->set_modelid($catid)) return false; 
    8.   
    9.     $this->hits_db = pc_base::load_model('hits_model'); 
    10.     $sql = $desc = $ids = ''
    11.     $array = $ids_array = array(); 
    12.     $order = $data['order']; 
    13.     $hitsid = 'c-'.$this->modelid.'-%'
    14.     $sql = "hitsid LIKE '$hitsid'"
    15.     if(isset($data['day'])) { 
    16.         $updatetime = SYS_TIME-intval($data['day'])*86400; 
    17.         $sql .= " AND updatetime>'$updatetime'"
    18.     } 
    19.     if($this->category[$catid]['child']) { 
    20.         $catids_str = $this->category[$catid]['arrchildid']; 
    21.         $pos = strpos($catids_str,',')+1; 
    22.         $catids_str = substr($catids_str$pos); 
    23.         $sql .= " AND catid IN ($catids_str)"
    24.     } else { 
    25.         $sql .= " AND catid='$catid'"
    26.     } 
    27.     $hits = array(); 
    28.     $result = $this->hits_db->select($sql'*'$data['limit'], $order); 
    29.     foreach ($result as $r) { 
    30.         $pos = strpos($r['hitsid'],'-',2) + 1; 
    31.         $ids_array[] = $id = substr($r['hitsid'],$pos); 
    32.         $hits[$id] = $r
    33.     } 
    34.     $ids = implode(','$ids_array); 
    35.     if($ids) { 
    36.         $sql = "status=99 AND id IN ($ids)"
    37.     } else { 
    38.         $sql = ''
    39.     } 
    40.     $this->db->table_name = $this->tablename; 
    41.     $result = $this->db->select($sql'*'$data['limit'],'','','id'); 
    42.     foreach ($ids_array as $id) { 
    43.         if($result[$id]['title']!='') { 
    44.             $array[$id] = $result[$id]; 
    45.             $array[$id] = array_merge($array[$id], $hits[$id]); 
    46.         } 
    47.     } 
    48.     return $array

    修改代碼(見注釋):

     
    1. /** 
    2.  * 排行榜標(biāo)簽 
    3.  * @param $data 
    4.  */ 
    5. public function hits($data) { 
    6.     $catid = intval($data['catid']); 
    7.   
    8.     $this->hits_db = pc_base::load_model('hits_model'); 
    9.     $sql = $desc = $ids = ''
    10.     $array = $ids_array = array(); 
    11.     $order = $data['order']; 
    12.     $hitsid = 'c-'.$this->modelid.'-%'
    13.     $sql = "hitsid LIKE '$hitsid'"
    14.     if(isset($data['day'])) { 
    15.         $updatetime = SYS_TIME-intval($data['day'])*86400; 
    16.         $sql .= " AND updatetime>'$updatetime'"
    17.     } 
    18.     if(!emptyempty($catid) && $catid>0) { //添加判斷:id是否為空 
    19.         if(!$this->set_modelid($catid)) return false; 
    20.         if($this->category[$catid]['child']) { 
    21.             $catids_str = $this->category[$catid]['arrchildid']; 
    22.             $pos = strpos($catids_str,',')+1; 
    23.             $catids_str = substr($catids_str$pos); 
    24.             $sql .= " AND catid IN ($catids_str)"
    25.         } else { 
    26.             $sql .= " AND catid='$catid'"
    27.         } 
    28.     } 
    29.       
    30.     $hits = array(); 
    31.     $result = $this->hits_db->select($sql'*'$data['limit'], $order); 
    32.     foreach ($result as $r) { 
    33.         $pos = strpos($r['hitsid'],'-',2) + 1; 
    34.         $ids_array[] = $id = substr($r['hitsid'],$pos); 
    35.         $hits[$id] = $r
    36.     } 
    37.     $ids = implode(','$ids_array); 
    38.     if($ids) { 
    39.         $sql = "status=99 AND id IN ($ids)"
    40.     } else { 
    41.         $sql = ''
    42.     } 
    43.     $this->db->table_name = $this->tablename; 
    44.     $result = $this->db->select($sql'*'$data['limit'],'','','id'); 
    45.     foreach ($ids_array as $id) { 
    46.         if($result[$id]['title']!='') { 
    47.             $array[$id] = $result[$id]; 
    48.             $array[$id] = array_merge($array[$id], $hits[$id]); 
    49.         } 
    50.     } 
    51.     return $array

    修改代碼后,無論設(shè)置欄目id為0或空,都能調(diào)取全站文章排行。

    調(diào)用方法1:

    {pc:content  action="hits" catid="0" num="10" order="views DESC" cache="3600"}

    調(diào)用方法2:

    {pc:content  action="hits" num="10" order="views DESC" cache="3600"}

    作者:Esion  來源:http://www.cnblogs.com/esion  轉(zhuǎn)載請注明出處

     


    本頁內(nèi)容由塔燈網(wǎng)絡(luò)科技有限公司通過網(wǎng)絡(luò)收集編輯所得,所有資料僅供用戶參考了本站不擁有所有權(quán),如您認(rèn)為本網(wǎng)頁中由涉嫌抄襲的內(nèi)容,請及時與我們聯(lián)系,并提供相關(guān)證據(jù),工作人員會在5工作日內(nèi)聯(lián)系您,一經(jīng)查實,本站立刻刪除侵權(quán)內(nèi)容。本文鏈接:http://www.juherenli.com/28191.html
    相關(guān)
     八年  行業(yè)經(jīng)驗

    多一份參考,總有益處

    聯(lián)系深圳網(wǎng)站公司塔燈網(wǎng)絡(luò),免費獲得網(wǎng)站建設(shè)方案及報價

    咨詢相關(guān)問題或預(yù)約面談,可以通過以下方式與我們聯(lián)系

    業(yè)務(wù)熱線:余經(jīng)理:13699882642

    Copyright ? 2013-2018 Tadeng NetWork Technology Co., LTD. All Rights Reserved.    

    中国精品18videosex性中国| 精品国产免费人成电影在线观看| 国产自产拍精品视频免费看| 2021国产精品自在拍在线播放| 在线亚洲精品福利网址导航| 国产精品嫩草影院线路| 99久久久精品免费观看国产| 久久精品中文字幕免费| 国产一区二区精品尤物| 日韩精品一区二区三区视频| 久久久久人妻精品一区三寸 | 久久综合九色综合精品| 天天爽夜夜爽夜夜爽精品视频| 久久精品无码一区二区三区免费| 亚洲精品午夜在线观看| 久久的精品99精品66| 国内精品久久人妻互换| 久久97久久97精品免视看秋霞 | 热99re久久精品精品免费| 精品久久久久久久无码| 99亚洲精品高清一二区| 久久精品亚洲一区二区| 亚洲日韩精品一区二区三区无码 | 国产精品特级毛片一区二区三区| 国产精品 羞羞答答在线| 四虎AV永久在线精品免费观看| 精品国产一区二区三区免费看 | 久久精品一本到99热免费| 久久久九九有精品国产| 亚洲精品色午夜无码专区日韩| 久久97久久97精品免视看秋霞| 亚洲视频在线精品| 亚洲综合精品网站| 国产精品99爱免费视频| 亚洲无码日韩精品第一页| 国产高清在线精品一区二区| 国产精品龙口护士门在线观看| 伊在人亚洲香蕉精品区麻豆| 永久免费精品影视网站| 国产精品国产三级国产潘金莲| 亚洲精品黄色视频在线观看免费资源|