DedeCMS V5.7中的TAG标签的URL一般是
http://域名/tags.php?/%B0%D9%B6%C8%BF%EC%D5%D5/
做成TAG伪静态修改参考文章《DedeCMS实现TAG伪静态(万网虚拟主机)》,中文字符的URL一样能被百度和谷歌识别,但介于中文URL路径过长可以替换为该TAG的ID。
在差不多87行找到
$row['link'] = $cfg_cmsurl."/tags.php?/".urlencode($row['keyword'])."/"; |
将其改成
$row['link'] = $cfg_cmsurl."/tags/".urlencode($row['id'])."/"; |
这样就把每个动态的tag标签生成了如:
http://域名/tags/12/
很多人设计TAG标签URL后面有“.html的”后缀,其实直接用斜杠“/”更好,代表这是一个目录。
$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}' ");
由于TAG替换成了ID,原有的调用方法有些变化,访问的tag列表如果用{dede:field.title/}调用的是ID,这不友好,下面是修改及调用方法
//设置一些全局参数的值foreach($GLOBALS['PubFields'] as $k=>$v) $this->Fields[$k] = $v; |
下面增加
//by CUOxin.com$s = $this->dsql->GetOne("Select tag From `#分隔符@__tagindex` where id = '{$this->Tag}' ");$this->Fields['tag'] = $s['tag'];$this->Fields['title'] = $s['tag'];//end |
往下继续找到
$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}' "); |
一般在站内都是用GetTags()函数调用,但这个函数并没有对应的ID。查看了一下taglist表,发现用的是tid。
[field:id function=GetTags(@me)/],调出来的会是/tags//
$query = "SELECT tag FROM `#分隔符@__taglist` WHERE aid='$aid' ";$dsql->Execute('tag',$query);while($row = $dsql->GetArray('tag')){ $tags .= ($tags=='' ? $row['tag'] : ','.$row['tag']);} |
这里增加了绝对路径的修改。
$query = "SELECT tid,tag FROM `#分隔符@__taglist` WHERE aid='$aid' ";$dsql->Execute('tid',$query);while($row = $dsql->GetArray('tid')){ $tags .= "<a href='".$GLOBALS['cfg_basehost']."/tags/".urlencode($row['tid'])."/'>".$row['tag']."</a>";} |
{dede:tag row='100' sort='new' getall='1'} <a target="_blank" href='[field:link/]'>[field:tag /]</a>{/dede:tag} |
有几个参数需要了解
row:调用条数sort:排序方式 month,rand,weekgetall:获取类型 0 为当前内容页TAG标记,1为获取全部TAG标记 |
{dede:tag row='10' sort='new' getall='0'}<a target="_blank" href='[field:link/]'>[field:tag /]</a>{/dede:tag} |
{dede:arclist row='10' titlelen='80'} <a target="_blank" href="[field:link/]">[field:id function=GetTags(@me)/]</a>{/dede:arclist} |
TAG列表页也是用的上述方法。
不能直接用{dede:field.title/}调用TAG标签了,这时调出来的是该TAG的ID,需要用SQL的方法调用,下面的橙色表前缀请自行更换。
{dede:sql sql="select tag from #分隔符@__tagindex where id=~title~"}[field:tag/]{/dede:sql} |
新闻热点
疑难解答