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

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 [email protected]";

$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}

时间: 2024-08-07 08:37:27

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

新辰:详解首页被K后SEOer必做的三大排除方法!

近段时间,有很多朋友向新辰抱怨说出大问题了,为神马site不到首页了,而且收录变成了0?唉,新辰不得不很同情的告诉你:你的首页真的被K了!好了,作为一个职业SEOer,面对被K犹如已经看破红尘般没了脾气,所以,废话少说,身为SEOer的你赶紧补救吧!希望新辰的这些方法能够帮助你早日逃离拔毛的痛苦哦: 所谓治病先察言观色,后开方救人,新辰说的就是先找准病因,才能给出解决的办法.面对突然site不到首页的情况,请先保持冷静哦,然后需要先查看一下收录和排名怎么样了,索引量如何,蜘蛛日志的返回代码是多少

详解首页被K后SEOer必做的三大排除方法!

近段时间,有很多朋友向新辰抱怨说出大问题了,为神马site不到首页了,而且收录变成了0?唉,新辰不得不很同情的告诉你:你的首页真的被K了!好了,作为一个职业SEOer,面对被K犹如已经看破红尘般没了脾气,所以,废话少说,身为SEOer的你赶紧补救吧!希望新辰的这些方法能够帮助你早日逃离拔毛的痛苦哦: 所谓治病先察言观色,后开方救人,新辰说的就是先找准病因,才能给出解决的办法.面对突然site不到首页的情况,请先保持冷静哦,然后需要先查看一下收录和排名怎么样了,索引量如何,蜘蛛日志的返回代码是多少

Dede后台验证码不显示解决方法详解(dedecms 5.7)

今天朋友问我他本地与服务器上安装了dedecms5.7无法显示验证码,一般这种情况很少见,一般情况就是服务器设置问题,还有临时目录的权限问题 Dede后台验证码不显示或不正常分三种情况,下面来逐一分析 Dede后台验证码不显示情况一 Dede后台验证码不显示情况二 Dede后台验证码不显示情况三 通用解决方案---取消后台验证码功能 因为没有验证码 不能进后台 所以修改php文件源代码: 方法一: 打开dede/login.php 找到如下代码 if(($validate=='' || $val

详解Integer.toString(int i)方法和String.valueOf(int i)方法

通过查看String类的源码: public static String valueOf(int i) { return Integer.toString(i); } 我们可以看到,String.valueOf(int i)其实是调用了Integer.toString(int i)方法的. 再次通过查看Integer类的源码我们可以看到: public static String toString(int i) { if (i == Integer.MIN_VALUE) return "-214

详解基于MSSQL “order by”语句报错的SQL注入技术

SQL注入,又名黑客技术之母,是一种臭名昭著的安全漏洞,由于流毒甚广,已经给网络世界造成了巨大的破坏.当然,对于该漏洞的利用技术,也是花样繁多,如访问存储在数据库中的数据,使用MySQL的load和into outfile语句读写服务器代码,以及使用SA帐户在MSSQL中执行命令,等等. 在本文中,我们要利用的SQL注入漏洞出现在下面的情形中:当用户提供的数据通过MSSQL的“Order By”语句中的值进行传递时,如果SQL查询中存在语法错误,那么应用程序就会抛出SQL Server错误. 如

Android ActionBar详解(三):ActionBar实现切换Tabs标签

实现切换Tabs标签; Activity代码: public class ActionBarTabs extends Activity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.action_bar_tabs); } public void onAddTab(View v) { final 

tars framework 源码解读(三) servant部分章节。客户端部分。完整的tars调用流程详解

一般tars客户端使用方式: 我们用客户端进行tars rpc调用时候,一般如下面这样写: 方式一. //直连方式 TC_Endpoint ep; AdminFPrx pAdminPrx; //服务管理代理 string sAdminPrx = "[email protected]"+_serverObjectPtr->getLocalEndpoint().toString(); pAdminPrx = Application::getCommunicator()->str

ASP.NET运行时详解 中篇

遗留问题 在ASP.NET运行时详解 上篇中遗留两个问题,包括Application的InitInternal方法执行细节.IIS6和II7经典模式请求管道管理类ApplicationStepManager和IIS7请求管道管理类PipelineStepManager的实现细节.这两个问题贯穿了整个ASP.NET运行过程.所以,要把ASP.NET运行过程了解清楚,这两个问题不得不解决.    为了大家更容易切入该篇的内容,我们先回顾下这两个问题: 1. Application的InitInter

(转载)log4net 组件详解

1.概述 log4net是.Net下一个非常优秀的开源日志记录组件.log4net记录日志的功能非常强大.它可以将日志分不同的等级,以不同的格式,输出到不同的媒介.本文主要是介绍如何在Visual Studio2008中使用log4net快速创建系统日志,如何扩展以输出自定义字段. 2.一个简单的使用实例 第一步:在项目中添加对log4net.dll的引用,这里引用版本是1.2.10.0. 第二步:程序启动时读取log4net的配置文件. 如果是CS程序,在根目录的Program.cs中的Mai