织梦dedecms图片集模板实现点击图片进入下一页

织梦教程 强烈建议 2024-02-06 13:44 83 0

  织梦dedecms的图片集模板里面的图片展示功能太勉强,习惯了点击图片查看下一张图的网友们很不习惯。那么,此功能能否在dedecms上实现?又该如何实现呢?

  此教程教大家如何实现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",""."\${0}"."",$body);

  }

  else

  {

  $PageList=""."\${0}"."";

  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']="下一篇:{$nextRow['title']} ";下面插入如下内容(大概在825行):

  $this->PreNext['imgnext']=""."\${0}"."";

  3、在$this->PreNext['next']="下一篇:没有了 ";下面插入如下内容(大概在830行):

  $this->PreNext['imgnext']=""."\${0}"."";

  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 搜索具体的代码位置。



时间:(2024-02-06 13:44:10)
本站资源均来自互联网或会员发布,如果不小心侵犯了您的权益请与我们联系。我们将立即删除!谢谢!