自定义织梦DedeCMS上一篇下一篇调用标签并且修改样式

织梦DedeCMS默认的文章上一页下一页只能调用文章标题和链接,在做模板的时候能实现的样式十分有限,有时我们需要获取上一篇文章封面缩微图,这样默认的调用标签就显得很LOW了。并且在没有上一篇或者下一篇文章的时候DedeCMS还会输出一个“没有了”的文字在对应的位置,看起来很碍眼。今天来分享一个dedecms的二次开发方案,来实现文章上下篇的美化。

dedecms二次开发美化上一篇 下一篇具体执行步骤,打开/include/arc.archives.class.php搜索下面内容

  1. else if($ctag->GetName()=='fieldlist')

在他的上面加入下面代码:

  1.     else if($ctag->GetName()=='prenextdiy')
  2.     {
  3.     	$innertext = trim($ctag->GetInnerText());	if($innertext)
  4.     	{
  5.     		$get = $ctag->GetAtt('get');
  6.     		$diys['diy'] = $this->GetPreNext('diy');
  7.     		$revalue = '';
  8.     		$dtp2 = new DedeTagParse();
  9.     		$dtp2->SetNameSpace('field','[',']');
  10.     		$dtp2->LoadSource($innertext);		foreach($diys as $row)
  11.     		{			foreach($dtp2->CTags as $tid=>$ctag2)
  12.     			{				if(isset($row[$get][$ctag2->GetName()]))
  13.     				{
  14.     					$dtp2->Assign($tid,$row[$get][$ctag2->GetName()]);
  15.     				}
  16.     			}
  17.     			$revalue .= $dtp2->GetResult();
  18.     		}		if($row[$get]['id']) $this->dtp->Assign($i,$revalue);
  19.     	}
  20.     }

搜索下面一行代码:

  1. $this->PreNext['pre'] = "上一篇:<a href='$mlink'>{$preRow['title']}</a> ";

然后在它上面插入下面代码:

  1.     $preRow['litpic'] = (empty($preRow['litpic'])) ? $GLOBALS['cfg_cmspath'].'/images/defaultpic.gif' : $preRow['litpic'];
  2.     $this->PreNext['diy']['pre']['id'] = $preRow['id'];
  3.     $this->PreNext['diy']['pre']['arcurl'] = $mlink;
  4.     $this->PreNext['diy']['pre']['title'] = $preRow['title'];
  5.     $this->PreNext['diy']['pre']['litpic'] = $preRow['litpic'];
  6.     $this->PreNext['diy']['pre']['pubdate'] = $preRow['senddate'];

继续搜索下面一行代码:

  1. $this->PreNext['next'] = "下一篇:<a href='$mlink'>{$nextRow['title']}</a> ";

在它上边添加以下代码:

  1.     $nextRow['litpic'] = (empty($nextRow['litpic'])) ? $GLOBALS['cfg_cmspath'].'/images/defaultpic.gif' : $nextRow['litpic'];
  2.     $this->PreNext['diy']['next']['id'] = $nextRow['id'];
  3.     $this->PreNext['diy']['next']['arcurl'] = $mlink;
  4.     $this->PreNext['diy']['next']['title'] = $nextRow['title'];
  5.     $this->PreNext['diy']['next']['litpic'] = $nextRow['litpic'];
  6.     $this->PreNext['diy']['next']['pubdate'] = $nextRow['senddate'];

最后再搜索代码:

  1. if($gtype=='pre')

在其前面插入:

  1.     if($gtype=='diy')
  2.     {	return $this->PreNext['diy'];
  3.     }

至此大功告成。

调用方法:

上一篇:

  1.     {dede:prenextdiy get='pre'}
  2.     <li><a href="[field:arcurl/]"><img src="[field:litpic/]" width="50" height="50"></a></li>
  3.     <p><a href="[field:arcurl/]">[field:title/]</a><span>时间:[field:pubdate function="MyDate('Y-m-d',@me)"/]</span></p>
  4.     {/dede:prenextdiy}

下一篇:

  1.     {dede:prenextdiy get='next'}
  2.     <li><a href="[field:arcurl/]"><img src="[field:litpic/]" width="50" height="50"></a></li>
  3.     <p><a href="[field:arcurl/]">[field:title/]</a><span>时间:[field:pubdate function="MyDate('Y-m-d',@me)"/]</span></p>
  4.     {/dede:prenextdiy}

这样,有了文字、图片、时间、链接。想美化成什么样子都可以了!并且不同的组合对网站的SEO优化也是很有帮助的。

并且,最关键的是这种织梦cms二次开发的方案非常优秀,因为原理是额外添加了一个diy的标签,所以完全不损伤系统原有的功能,如有需求,依旧可以使用织梦系统原有的标签进行上下篇的调用。