首页 > CMS > 织梦DEDE > 正文

DedeCms图片集模板实现点击图片进入下一页

2024-07-12 08:28:42
字体:
来源:转载
供稿:网友
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 搜索具体的代码位置。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表