dedecms织梦tag标签详解

时间:2014-09-26

 标签名称:tag

 功能说明:TAG调用标签

 适用范围:全局使用

 DEDECMS的tags调用的基本语法是:

  {dede:tag sort='new' getall='0'}

  <a href='[field:link/]'>[field:tag /]</a>

  {/dede:tag}

参数说明:

  row='30' 调用条数,sort='new' ,排序方式 month,rand,week ,getall='0' 获取类型 0 为当前内容页TAG标记,1为获取全部TAG标记,底层模板字段,link和tag。

  但是我们知道dede默认在列表是无法调用tag标签的,是用全部还是当前页?显然全部的话和分类信息又有些不着调,如果用当前页的话,没有文章id,你也调不出东西来。难道这就没辙了吗?

  方法1:

  在列表需要的位置加入下列代码

[field:id runphp=yes]

$tsql = new DedeSql(false);  

$tags = '';  

$tsql->SetQuery("Select i.tagname From dede_tag_list t left join dede_tag_index i on i.id=t.tid where t.aid='@me'");

$tsql->Execute('t');

while($row = $tsql->GetArray('t',MYSQL_ASSOC)){

  $tags .= "<a href='/tag.php?/".urlencode($row['tagname'])。"'>".$row['tagname']."</a>";

  }  

  @me=$tags;

 [/field:id]

   方法2:

在inc_functions.php文件里加入

function listtag($aid){

  $tsql = new DedeSql(false);  

  $tags = '';  

  $tsql->SetQuery("Select i.tagname From dede_tag_list t left join dede_tag_index i on i.id=t.tid where t.aid='$aid'");   $tsql->Execute('t');

  while($row = $tsql->GetArray('t',MYSQL_ASSOC)){

  $tags .= "<a href='/tag.php?/".urlencode($row['tagname'])。"'>".$row['tagname']."</a>";  

  }  

  return $tags;  

  }    然后在列表页相应位置加入[field:ID function="listtag(@me)"/]标记。看了一下5.7版本的DedeCMs里面关于tag的调用,虽然也有typeid的参数了,但是你打开数据库看看就会发现,虽然dede_tagindex表里面也有了typeid的字段。但是默认值都是0.这样代码中的sql语句就没有任何作用了,反而家里typeid参数取不出数据来。

上一条:Dedecms织梦文章标题长度修改方法 下一条:织梦dedecms如何用sql语句删除全部文章和删除所有

相关文章

最新文章