详解织梦模板DEDECMS核心类TypeLink.class.php功能分析

所属分类: CMS教程 / dedecms 阅读数: 2200
收藏 0 赞 0 分享

DedeCMS 核心类TypeLink.class.php摘要笔记,学习php就是借鉴与分析,让自己的掌握的更多。

注:'//+' 表示为本人另外加上的注释

Class TypeLink 
{ 
var $typeDir; 
var $dsql; 
var $TypeID; //+ 类别ID 
var $baseDir; //+ 站点根网址 
var $modDir; //+ 模板目录 
var $indexUrl; //+ 主页链接地址 
var $indexName; //+ 主页链接名 
var $TypeInfos; //+ 类目信息 
var $SplitSymbol; //+ 栏目位置的间隔符号 
var $valuePosition; //+ 主页 > 国内 > 两会动态 > (带连接) 
var $valuePositionName; //+ 主页 > 国内 > 两会动态 > (不带连接) 
var $OptionArrayList; //+ 类目下拉列表 

功能一,获得某类目的链接

代码如下:

//获得某分类连接的URL  
function GetOneTypeUrl($typeinfos)  
{  
return GetTypeUrl();  
}  
//获得某个类目的超链接信息  
function GetOneTypeLink($typeinfos)  
{  
$typepage = $this->GetOneTypeUrl($typeinfos);  
$typelink = "<a href='".$typepage."'>".$typeinfos['typename']."</a>";  
return $typelink;  
}

功能二,获得某类目的链接列表 如:'类目一>类目二>' 这样的形式。

代码如下:

//islink 表示返回的列表是否带连接  
//+ SplitSymbol 栏目位置的间隔符号 dede系统默认为'-'  
function GetPositionLink($islink=true)  
{ //+ 获得 主页链接名  
$indexpage = "<a href='".$this->indexUrl."'>".$this->indexName."</a>";  
……  
……  
else  
{  
if($islink)  
{  
$this->valuePosition = $this->GetOneTypeLink($this->TypeInfos);  
if($this->TypeInfos['reid']!=0)  
{  
//调用递归逻辑  
$this->LogicGetPosition($this->TypeInfos['reid'],true);  
}  
$this->valuePosition = $indexpage.$this->SplitSymbol.$this->valuePosition;  
return $this->valuePosition.$this->SplitSymbol;  
}  
else  
{  
$this->valuePositionName = $this->TypeInfos['typename'];  
if($this->TypeInfos['reid']!=0)  
{  
//调用递归逻辑  
$this->LogicGetPosition($this->TypeInfos['reid'],false);  
}  
return $this->valuePositionName;  
}  
}  
}  
//获得某类目的链接列表,递归逻辑部分  
function LogicGetPosition($id,$islink)  
{  
$this->dsql->SetQuery(" SQL查询语句 ");  
$tinfos = $this->dsql->GetOne();  
if($islink)  
{ //+ 列表带连接  
$this->valuePosition = $this->GetOneTypeLink($tinfos).$this->SplitSymbol.$this->valuePosition;  
}  
else  
{ //+ 列表不带连接  
$this->valuePositionName = $tinfos['typename'].$this->SplitSymbol.$this->valuePositionName;  
}  
if($tinfos['reid']>0)  
{ //+ 递归  
$this->LogicGetPosition($tinfos['reid'],$islink);  
}  
}  

功能三, 获得类别列表 高级搜索功能 即highsearch.php 即要用到此函数

代码如下:

//hid 是指默认选中类目,0 表示"请选择类目"或"不限类目"  
//oper 是用户允许管理的类目,0 表示所有类目  
//channeltype 是指类目的内容类型,0 表示不限频道  
function GetOptionArray($hid=0,$oper=0,$channeltype=0,$usersg=0)  
{  
return $this->GetOptionList($hid,$oper,$channeltype,$usersg);  
}  
function GetOptionList($hid=0,$oper=0,$channeltype=0,$usersg=0)  
{  
return $this->OptionArrayList;  
}  
//+ 为下级类目递归加上 '-'  
function LogicGetOptionArray($id, $step, $oper=0)  
{  
} 

功能四,

//获得与该类相关的类目,本函数应用于模板标记{dede:channel}{/dede:channel}中 
//$typetype 的值为: sun 下级分类 self 同级分类 top 顶级分类 
代码如下:
function GetChannelList($typeid=0,$reid=0,$row=8,$typetype='sun',$innertext='',  
$col=1,$tablewidth=100,$myinnertext='')  
{  
}  
} 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

dedecms模板标签如何做判断示例代码

dedecms模板标签是可以做判断的,不过具体要看是哪个标签,有些标签是无法判断的。必须改源文件,下面有个示例,感兴趣的朋友可以参考下
收藏 0 赞 0 分享

DEDE [field:global name=autoindex/] 按序号排列从0从1开始

调试程序用到[field:global name=autoindex/ ] 调用指定频道而频道前面需要加CSS代码,CSS代码正好是按序号排列的,于是修改了一下代码,在此与大家分享下,感兴趣的朋友可以收藏下
收藏 0 赞 0 分享

DEDECMS的20位MD5加密密文解密示例介绍

dedecms的20位md5加密算噶是从32位md5中截取的20位,所以去掉前3位喝最后1位,即可获得16位md5值,即可破解15位md5,感兴趣的朋友可以了解下
收藏 0 赞 0 分享

织梦dedecms登录管理后台总是验证码错误的解决方案

织梦dedecms登录管理后台总是验证码错误在网上找了很多的解决方案,说法有很多种,但最后都无法解决这个问题,感兴趣的朋友可以了解下本文
收藏 0 赞 0 分享

如何让dedecms变成全站动态浏览有利于企业站

教大家如何让dedecms(织梦)变成全站动态浏览,对于企业站很有利哦!有时候dedecms全站的静态反而对于建设企业站不利,具体实现如下,感兴趣的朋友可以参考下,希望对大家有所帮助
收藏 0 赞 0 分享

使用dedecms搭建自己的本地网站(全程图解)

对于初学而言,网站都是在本地调试好后,才通过ftp上传到所买的空间或虚拟主机上,而无论是处于什么情况,学习在本地搭建网站的方法对于初学者是很有用的,下面与大家分享下具体的搭建过程
收藏 0 赞 0 分享

适合企业站的织梦常用标签大全(自己整理)

对于企业站而言其实不用了解那么多标签,在这里分享下自己总结的适合企业站的标签大全,希望大家收藏,以备不时之需
收藏 0 赞 0 分享

DEDECMS最为常用的分页标签及分页样式代码

今天我要分享的是我们最为常用的分页列表及分页样式代码,很多人在这个上面花费的时间较多,其实很简单,如果使用我下面的通用版本就很轻而易举的完工,感兴趣的朋友可以了解下
收藏 0 赞 0 分享

dede标签云如何生成不同颜色、不同大小的tag标签

tag标签做网站的朋友想必知道吧,在本文要为大家讲解的的是dede标签云的使用,如何生成不同颜色、不同大小的tag标签,感兴趣的朋友可以参考下
收藏 0 赞 0 分享

dedecms列表页标题title后加上页数其标题不重复的方法

在列表页的标题后加上页数使列表页的标题不重复这样更利于优化,下面是从搜索整理的解决方法,有类似需求的朋友可以参考下,希望对大家有所帮助
收藏 0 赞 0 分享
查看更多