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
{