织梦CMS可以为网站增加大量的页面,必须处理得当,否则会产生非常多的垃圾页面。页面SEO优化的三要素Title、Keywords、Description。最重要的是Title,而TAG页面没有对应的Descripition描述,可以把当前TAG标签写成描述也可以,但不灵活,下面提供为TAG标签增加描述,如图
数据库部分修改
方法一:用Navicat数据库管理工具打开dede_tagindex数据表,依次点击文件 -> 设计表,如图
新建tagms字段,类型varchar,长度255,允许空值。
方法二:或者在织梦后台执行sql语句
alter table `dede_tagindex` add `tagms` varchar(255) NOT NULL
织梦管理后台部分修改
打开后台/dede/tags_main.php,大概在27行找到
$dlist->SetParameter("tag", $tag);
下面增加
$dlist->SetParameter("tagms", $tagms); 
大概在49行找到
$query = "UPDATE `#@_tagindex` SET `count`='$count' WHERE id='$tid' ";
修改为
$query = "UPDATE `#@_tagindex` SET `count`='$count',`tagms`='$tagms'WHERE id='$tid' ";
大概在147行找到
$query = " INSERT INTO `#@_tagindex`(`tag`,`count`,`total`,`weekcc`,`monthcc`,`weekup`,`monthup`,`addtime`) VALUES('$keyword','0','1','0','0','$timestamp','$timestamp','$timestamp');";
修改为
$query = " INSERT INTO `#@_tagindex`(`tag`,`tagms`,`count`,`total`,`weekcc`,`monthcc`,`weekup`,`monthup`,`addtime`) VALUES('$keyword','$tagms','0','1','0','0','$timestamp','$timestamp','$timestamp');";
打开/dede/templets/tags_main.htm,找到更新的JS
function UpdateOne(tid) { location = "tags_main.php?action=update&count="+document.getElementById('count'+tid).value+"&tid="+tid;
增加描述的参数,代码修改为
function UpdateOne(tid) { location = "tags_main.php?action=update&count="+document.getElementById('count'+tid).value+"&tagms="+document.getElementById('ms'+tid).value+"&tid="+tid;
找到
<td width="10%">标签</td>
下面增加
<td width="35%">描述</td>
找到
<td> <a href="../tags.php?/<?php echo urlencode($fields['tag']); ?>/" target="_blank">{dede:field.tag /}</a> </td>
下面增加
<td> <textarea name="" rows="" cols="" id="ms<?php echo $fields['id']; ?>" ><?php echo $fields['tagms'];?></textarea> </td>
由于增加了一列,后台其他地方的样式就自行解决了
打开/include/taglib/tag.lib.php,找到
$row['link'] = $cfg_cmsurl."/tags.php?/".urlencode($row['keyword'])."/";
修改为
$row['link'] = $cfg_cmsurl."/tags/php?/".urlencode($row['id'])."/";
打开/include/arc.taglist.clss.php,找到
$this->TagInfos = $this->dsql->GetOne("Select * From `#@_tagindex` where tag like '{$this->Tag}' ");
修改为
$this->TagInfos = $this->dsql->GetOne("Select * From `#@_tagindex` whereidlike '{$this->Tag}' ");
模板部分调用
{dede:sql sql="select * from dede_tagindex where tag=~title~ "}[field:tagms/]{/dede:sql}