当前位置:首页 > 技术教程 > dede技术教程 > 正文内容

DedeCMS织梦增加TAG标签SEO描述

访客4年前 (2020-11-16)dede技术教程6124

DedeCMS可以为网站增加大量的页面,必须处理得当,否则会产生非常多的垃圾页面。页面SEO优化的三要素Title、Keywords、Description。最重要的是Title,而TAG页面没有对应的Descripition描述,可以把当前TAG标签写成描述也可以,但不灵活,下面提供为TAG标签增加描述,如图

数据库部分修改

用Navicat数据库管理工具打开dede_tagindex数据表,依次点击文件 -> 设计表,如图

新建tagms字段,类型varchar,长度255,允许空值。

管理后台部分修改

打开后台/dede/tags_main.php,大概在27行找到

$dlist->SetParameter("tag", $tag);

下面增加

$dlist->SetParameter("tagms", $tagms); //by www.vi586.com

大概在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` where id like '{$this->Tag}' ");

模板部分调用

{dede:sql sql="select * from dede_tagindex where id=~title~"}[field:tagms/]{/dede:sql}

其他调用方法参考文章《DedeCMS把TAG的URL替换成ID》

声明:
本站大部分资源收集于网络,只做学习和交流使用,版权归原作者所有。
若您需要使用非免费的软件或服务,请购买正版授权并合法使用!
本站发布的内容若侵犯到您的权益,请联系站长删除,我们将及时处理!

分享给朋友:

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。