您现在的位置是:首页 > 教程 > dedecms教程dedecms教程

dedecms织梦副栏目名称和链接调用的方法

乐武亮2023-09-16 12:40:40dedecms教程已有人查阅

导读打开 \include\extend.func.php 在最下面加入/*** 获取副栏目链接和名称** @access public* @para

打开 \include\extend.func.php 在最下面加入
/**
 *  获取副栏目链接和名称
 *
 * @access    public
 * @param     string  $typeid2 副栏目id
 * @param     string  $result   输出
 * @return    string
 */
if(!function_exists('GetTypeid2'))
{
function GetTypeid2($typeid2)
{
global $dsql;
$result = '';
$query = "SELECT * FROM `dede_arctype` WHERE id IN($typeid2) AND ishidden<>1 ORDER BY FIELD(id,$typeid2)";
$dsql->Execute('t',$query);
while($row = $dsql->GetArray('t'))
{
$typeurl = GetOneTypeUrlA($row);
$result.= ($result=='' ? "<a href='{$typeurl}'>{$row['typename']}</a>" : ','."<a href='{$typeurl}'>{$row['typename']}</a>");
}
return $result;
}
}
列表页 调用标签写法
[field:typeid2 function=GetTypeid2(@me)/]
内容页 调用标签写法
{dede:field.typeid2 function=GetTypeid2(@me)/}
首页 调用标签
还需要打开 /include/taglib/arclist.lib.php 找到
if($CrossID=='') $orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).')';
改成
if($CrossID=='') $orwheres[] = " (arc.typeid in (".GetSonIds($typeid).") or arc.typeid2 in (".GetSonIds($typeid).") or CONCAT( ',', arc.typeid2, ',' ) LIKE '%,".$typeid.",%' )";
继续找到
else $orwheres[] = ' arc.typeid IN ('.GetSonIds($typeid).','.$CrossID.')';
改成
else $orwheres[] = " (arc.typeid in (".GetSonIds($typeid).",".$CrossID.") or arc.typeid2 in (".GetSonIds($typeid).",".$CrossID.") or CONCAT( ',', arc.typeid2, ',' ) LIKE '%,".$typeid.",%')";
这样才可以在首页调用副栏目,标签写法是
[field:typeid2 function=GetTypeid2(@me)/]

本文标签:

很赞哦! ()

留言与评论 (共有 条评论)
验证码:

本栏推荐

相关标签