做網站,我們是認真的!

網站適配電腦+手機端,僅1280元,送2000M阿里云服務器,送com域名+免費備案
網站前端采用靜態系統顯示,后端動態管理,我們承諾網站包收錄,完成網站之后把源碼給客戶!

觀點

互聯網+時代,說建站,談運營與網絡營銷

DedeCms圖片集模板實現點擊圖片進入下一頁

時間:2020-12-16

dedecms的圖片集模板里面的圖片展示功能太勉強,習慣了點擊圖片查看下一張圖的網友們很不習慣。那么,此功能能否在dedecms上實現?又該如何實現呢?織夢58小編在此給大家分享一下實現的方法。
 
此教程教大家如何實現DedeCms圖片模型,點擊圖片進入下一張圖片,最后一張圖片進入下一篇圖片。(親測有效
嘉綿之戀用于測試的是DedeCmsV5.7SP1版本,其他版本未測試,請慎用。
 
首先打開include/arc.archives.class.php
 
1、672行處插入以下內容,即“解析模板,對內容里的變動進行賦值”注釋的上一行:
 
//點擊進入下一頁   
    function ClickPicNext($ismake=1,$aid,&$body)   
    {   
        global $cfg_rewrite;   
        if($this->NowPage!=$this->TotalPage)   
        {   
            $lPage=$this->NowPage+1;   
            if($ismake==1)   
            {   
                $body=preg_replace("/<(img|IMG)(.*)(src|SRC)=[\"|'| ]{0,}((.*)>)/isU","<a href='".$this->NameFirst."_".$lPage.".".$this->ShortName."'>"."\${0}"."</a>",$body);   
            }   
            else
            {   
                $PageList="<a href='view.php?aid=$aid&pageno=$lPage'>"."\${0}"."</a>";   
                if($cfg_rewrite == 'Y')   
                {   
                    $PageList = str_replace(".php?aid=","-",$PageList);   
                    $PageList = preg_replace("/&pageno=(\d+)/i",'-\\1.html',$PageList);   
                }   
                $body=preg_replace("/<(img|IMG)(.*)(src|SRC)=[\"|'| ]{0,}((.*)>)/isU",$PageList,$body);   
            }   
        }   
        else
        {   
            $body=preg_replace("/<(img|IMG)(.*)(src|SRC)=[\"|'| ]{0,}((.*)>)/isU",$this->GetPreNext('imgnext'),$body);   
        }   
        return $body;   
    }
 
2、
 
$this->PreNext['next'] = "下一篇:<a href='$mlink'>{$nextRow['title']}</a> ";
 
下面插入如下內容(大概在825行):
 
$this->PreNext['imgnext'] ="<a href='$mlink'>"."\${0}"."</a>";
 
3、
 
$this->PreNext['next'] = "下一篇:沒有了 ";
下面插入如下內容(大概在830行):
 
$this->PreNext['imgnext'] ="<a href='$mlink'>"."\${0}"."</a>";
 
4、
 
$this->Fields[$this->SplitPageField] = $this->SplitFields[$pageNo - 1];
下面插入如下內容(大概在715行):
 
if($ClickPicNext)  
            {  
                $this->Fields[$this->SplitPageField]=$this->Fields[$this->SplitPageField];  
            }  
            else
            {  
                $this->Fields[$this->SplitPageField]=$this->ClickPicNext($ismake,$this->Fields['id'],$this->Fields[$this->SplitPageField]);  
            }
 
5、
 
else if($gtype=='nextimg'){   
                      
            $rs =  $this->PreNext['nextimg'];   
        }
下面插入如下內容(大概在849行):
 
else if($gtype=='imgnext')   
        {   
        $rs =  $this->PreNext['imgnext'];   
        }
修改上面五處即可實現點擊圖片進入下一張圖片,點擊最后一張圖片進入下一篇圖集。
 
溫馨提示:
1、修改的時候請注意備份,以免出錯。
2、上面提到的“大概在N行”僅供參考,實際操作中建議使用 ctrl+f 搜索具體的代碼位置。
0
首頁
案例
關于
聯系
凯时平台