详解Dedecms各种形式的栏目调用标签,包括SQL调用方法

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

DedeCMS获取文档当前栏目所在目录链接URL


DedeCMS内容页调用当前栏目其实用下来是调用不出来的,{dede:field.typename/}是有效的,可是 {dede:field.typeurl/}却调不出文档当前栏目所在目录链接URL。查了下网上有网友提供了解决的办法,贴出来大家分享:


方法一:

{dede:type typeid='0′ row=1}[field:typelink /]{/dede:type}


方法二:

动手改装一下函数了,利用DEDECMS自定义函数的接口文件,我们在文章页中的标记把


{dede:field.typeid function='typeurl_arc(@me)'/}


这个放在内容页的模板中,把如下函数:


function typeurl_arc($typeid){

$typeurl = ";

$dsql = new DedeSql(false);

$row = $dsql ->GetOne("select typedir from dede_arctype where id=$typeid");

$typeurl = MfTypedir($row['typedir']);

return $typeurl;


放到extend.func.php里。


注:MfTypedir为dedecms系统内置函数


dedecms获取当前文档url地址的方法


{dede:field name='arcurl'/}

====================================================================================

代码功能:父栏目及子栏目同时调用

使用说明……typeid,row

如果[field:typedir/]中含有{cmspath}而使链接无效,请使用[field:typedir function='str_replace("{cmspath}","",@me)'/] 此标签替换[field:typedir/]。

{dede:field name='typedir' runphp='yes'}

@me=str_replace("{cmspath}","",@me);

{/dede:field}

 

网上搜集的栏目调用代码:

 

一、二、三级栏目调用

{dede:channelartlist typeid=top row=4}

<div class="cpmll">

<span><a href="{dede:field name='typeurl'/}">{dede:field name='typename'/}</a></span>

<ul>

{dede:sql sql='Select * from dede_arctype where reid=~id~ ORDER BY id limit 0,7'}

<li><a href='[field:typedir/]' target='_blank'>[field:typename/]</a></li>

{/dede:sql}

</ul>

</div>

{/dede:channelartlist}

 

主栏目调用

{dede:channelartlist typeid=top row=''}

<li><a href="{dede:field name='typeurl'/}">{dede:field name='typename'/}</a>

<ul>

{dede:sql sql='Select * from dede_arctype where reid=~id~ ORDER BY id limit 0,7'}

[field:array runphp='yes']@me = (!empty(@me['reid']) ? "" : "<li><a href='{@me['typedir']}' target='_blank'>{@me['typename']}</a></li>"); [/field:array]

{/dede:sql}

</ul>

</li>

{/dede:channelartlist}

 

在列表页和内容页调用顶级栏目名称方法

{dede:field.typeid runphp='yes' function="GetTopid(@me)"}

$dsql = new DedeSql(false);

$a="SELECT typename FROM dede_arctype where id=@me";

$arcRow = $dsql->GetOne($a);

@me=$arcRow[typename];{/dede:field.typeid}


根据下级栏目获得顶级栏目名称的SQL语句

{dede:field.typeid runphp='yes'}

$ID = @me; 

$sql = "SELECT * FROM `dede_arctype` WHERE id=$ID";

$query = mysql_query($sql);

$row=mysql_fetch_array($query); 

$relID = "$row[reid]"; 

if($relID == 0) 

{

    @me = $row[typename];

}

else

{

    $sql = "SELECT `typename` FROM `dede_arctype` WHERE id=$relID";

    $query = mysql_query($sql);

    $row=mysql_fetch_array($query); 

    @me = $row[typename];

}

{/dede:field.typeid}

 

怎么在首页调用dede子栏目

{dede:channel type='son' typeid='栏目ID'}

<a href="[field:typelink/]">[field:typename/]</a>

{/dede:channel}



本文转自 gutaotao1989 51CTO博客,原文链接:http://blog.51cto.com/taoyouth/1726507

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
19天前
|
SQL 监控 安全
Flask 框架防止 SQL 注入攻击的方法
通过综合运用以上多种措施,Flask 框架可以有效地降低 SQL 注入攻击的风险,保障应用的安全稳定运行。同时,持续的安全评估和改进也是确保应用长期安全的重要环节。
137 71
|
27天前
|
SQL 安全 PHP
PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全
本文深入探讨了PHP开发中防止SQL注入的方法,包括使用参数化查询、对用户输入进行过滤和验证、使用安全的框架和库等,旨在帮助开发者有效应对SQL注入这一常见安全威胁,保障应用安全。
47 4
|
1月前
|
SQL BI 数据库
SQL操作的一些基本方法
【10月更文挑战第27天】SQL操作的一些基本方法
37 3
|
1月前
|
SQL 监控 固态存储
SQL优化有哪些方法?
【10月更文挑战第27天】SQL优化有哪些方法?
43 3
|
2月前
|
SQL 存储 数据库
SQL部分字段编码设置技巧与方法
在SQL数据库管理中,设置字段的编码对于确保数据的正确存储和检索至关重要
|
2月前
|
SQL 数据库 索引
SQL语句实现投影连接:方法与技巧详解
在SQL数据库查询中,投影和连接是两个核心概念
|
2月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
2月前
|
SQL 存储 Serverless
SQL语句拆分时间字段的技巧与方法
在数据库操作中,经常需要处理时间数据
|
2月前
|
SQL 监控 数据库
SQL语句是否都需要解析及其相关技巧和方法
在数据库管理中,SQL(结构化查询语言)语句的使用无处不在,它们负责数据的查询、插入、更新和删除等操作
|
2月前
|
SQL 关系型数据库 MySQL
如何查看SQL字符编码:详细技巧与方法
在SQL数据库管理中,字符编码对于确保数据的正确性和一致性至关重要