{dede:field name='topname'/}
来调用顶级栏目的名称。,3. 使用织梦标签
{dede:field name='topintro'/}
来调用顶级栏目的简介。,,示例代码:,,“html,,{dede:field name='topname'/},{dede:field name='topintro'/},,
“,,将以上代码插入到模板文件的相应位置,即可实现在子栏目中调用其所属顶级栏目的名称及简介。
在织梦CMS(DedeCMS)中,调用子栏目所属的顶级栏目的名称和简介可以通过多种方法实现,以下是几种常见的方法及其详细说明:
调用子栏目的顶级栏目名称
方法 | 代码示例 | 说明 |
方法一 | {dede:field.typeid runphp=’yes’} $ID = @me; $sql = “SELECT * FROMdede_arctype WHERE id=$ID”; $query = mysql_query($sql); $row=mysql_fetch_array($query); $relID = “$row[reid]”; if($relID == 0) {@me = $row[typename];} else{$sql = “SELECTtypename FROMdede_arctype WHERE id=$relID”; $query = mysql_query($sql); $row=mysql_fetch_array($query); @me = $row[typename];} {/dede:field.typeid} |
此方法通过SQL查询获取当前栏目的顶级栏目名称,如果顶级栏目没有上级栏目(即$relID为0),则直接返回当前栏目的类型名称;否则,继续查询顶级栏目的名称。 |
方法二 | {dede:field.title runphp=’yes’} list($toptype,$sontype)=split(‘/’,@me); @me=$toptype; {/dede:field.title} | 该方法通过分割当前栏目路径来获取顶级栏目名称,假设栏目路径格式为”顶级栏目/子栏目”,通过split函数分割后,取第一个元素即为顶级栏目名称。 |
方法三 | {dede:field.typeid runphp=’yes’} $ID = @me; $sql = “SELECT * FROMdede_arctype WHERE id=$ID”; $query = mysql_query($sql); $row=mysql_fetch_array($query); $relID = “$row[reid]”; $topID=”$row[topid]”; if($relID == 0) {@me = $row[typename];} else{$sql = “SELECTtypename FROMdede_arctype WHERE id=$topID”; $query = mysql_query($sql); $row=mysql_fetch_array($query); @me = $row[typename];} {/dede:field.typeid} |
此方法与方法一类似,但增加了对无限级子栏目的支持,通过查询当前栏目的顶级栏目ID($topID),然后获取其名称。 |
调用子栏目的顶级栏目简介
方法 | 代码示例 | 说明 |
方法一 | {dede:field name=’position’ runphp=’yes’} if ( !function_exists(‘GetTopInfo’) ) { function GetTopInfo($tid) { global $dsql; $row = $dsql>GetOne(“SELECT * FROM #@__arctype WHERE id=$tid”); return $row[‘typename’] . ‘ ‘ . $row[‘description’]; } } echo GetTopInfo(@me); {/dede:field} | 通过自定义函数GetTopInfo,传入当前栏目ID,查询并返回顶级栏目的名称和简介,注意,这里假设简介字段为description。 |
方法二 | {dede:field.typeid runphp=’yes’} $ID = @me; $sql = “SELECT * FROMdede_arctype WHERE id=$ID”; $query = mysql_query($sql); $row=mysql_fetch_array($query); $relID = “$row[reid]”; if($relID == 0) { $intro = $row[description]; } else{ $sql = “SELECTdescription FROMdede_arctype WHERE id=$relID”; $query = mysql_query($sql); $row=mysql_fetch_array($query); $intro = $row[description]; } @me = $intro; {/dede:field.typeid} |
类似于方法一,但直接在模板中进行SQL查询,获取顶级栏目的简介,如果顶级栏目没有上级栏目,则使用当前栏目的简介。 |
相关问答FAQs
1. 如何在列表页调用子栏目所属的顶级栏目名称?
答:在列表页调用子栏目所属的顶级栏目名称,可以使用以下代码:
{dede:field.typeid runphp='yes'} $ID = @me; $sql = "SELECT * FROMdede_arctype
WHERE id=$ID"; $query = mysql_query($sql); $row = mysql_fetch_array($query); $relID = "$row[reid]"; if($relID == 0) { @me = $row[typename]; } else { $sql = "SELECTtypename
FROMdede_arctype
WHERE id=$relID"; $query = mysql_query($sql); $row = mysql_fetch_array($query); @me = $row[typename]; } {/dede:field.typeid}
这段代码会查询当前栏目的顶级栏目名称,并在列表页中显示。
2. 如何在内容详情页调用子栏目所属的顶级栏目简介?
详情页调用子栏目所属的顶级栏目简介,可以使用以下代码:
{dede:field name='position' runphp='yes'} if ( !function_exists('GetTopInfo') ) { function GetTopInfo($tid) { global $dsql; $row = $dsql>GetOne("SELECT * FROM #@__arctype WHERE id=$tid"); return $row['typename'] . ' ' . $row['description']; } } echo GetTopInfo(@me); {/dede:field}
这段代码会定义一个名为GetTopInfo的函数,该函数接收一个栏目ID作为参数,查询并返回该栏目的顶级栏目名称和简介,在内容详情页中调用这个函数,传入当前栏目ID,即可显示顶级栏目的简介。