DedeCMS教程DedeCMS二次开发Word文档格式.docx
- 文档编号:16763100
- 上传时间:2022-11-25
- 格式:DOCX
- 页数:63
- 大小:48.29KB
DedeCMS教程DedeCMS二次开发Word文档格式.docx
《DedeCMS教程DedeCMS二次开发Word文档格式.docx》由会员分享,可在线阅读,更多相关《DedeCMS教程DedeCMS二次开发Word文档格式.docx(63页珍藏版)》请在冰豆网上搜索。
会员后台的模板。
四、二次开发
在V5.3中已经将标签开发分离出来,您可以通过后台[模板]-[标签代码管理],点击“新增加一个新的标签”来创建一个自己的标签,标签文件名为:
标签名.lib.php
接口函数定义为:
functionlib_标签名(&
$ctag,&
$refObj),返回值是结果字符串
修改标签时为了防止出错,您也可以修改它的名称(同时修改文件名和函数名),这样等同继承了原来标签的代码建立一个新的标签。
1.2、模板标签语法简介
织梦的模板标签类似于XML格式,所有的模板都含有定界符,默认情况下是{dede:
*}和{/dede:
*},“*”代表模板标记名称。
一般情况下{dede:
*}是成对出现的,例如:
例1-1:
1{dede:
arclistflag='
h'
limit='
0,1'
}<
br/>
2<
h2>
<
ahref="
[field:
arcurl/]"
>
title/]<
/a>
/h2>
3<
p>
description/]...<
[查看全文]<
/p>
4{/dede:
arclist}
上面的{dede:
arclist}和{/dede:
arclist}成对出现在模板文件中,并且在两个标签当中包含了底层模板(innertext)。
底层模板(Innertext),底层模板实际上就是对于有多条记录的模板输出,用户手工去指定单个记录的样式。
标签还有一类出现形式是{dede:
*/},通常以这种形式出现都是输出变量、或者不含底层模板的内容。
例如:
1-2
{dede:
global.cfg_webname/}
/}
如果用户没有指定单个记录的样式,系统部分标签都含有默认的底层模板,具体可以查看{cmapath}/templets/system/文件夹下面的文件,这里面都是系统的底层模板文件。
注释
织梦标签的模板注释非常灵活,可以通过标签后面的commet属性进行赋值。
例1-3:
commet='
调用头条的第一篇内容'
arcurlcommet="
这是文章链接标签"
/]"
titlecommet="
这是文章标题标签"
/]<
descriptioncommet="
这是摘要标签"
/]...<
在模板引擎将上述标签解析为html的时候,commet的内容是被忽略掉不去解析的,用户在阅读模板标记的时候可以更好的理解标签的意义。
函数
每一个织梦的标签都可以使用自定义函数对其进行扩展,自定义函数内容主要用于对当前标签输出内容进行处理。
例1-4:
标记名称function='
youfunction("
参数一"
"
参数二"
@me"
)'
其中@me用于表示当前标记的值,其它参数由你的函数决定是否存在,例如:
field.pubdatefunction='
strftime("
%Y-%m-%d%H:
%M:
%S"
属性
模板标签的属性,决定了模板标记输出的形式,例如arclist标签主要功能是列出文档列表,但列出什么内容、按照什么方式进行排序等取决于模板标签的属性。
在织梦的模板标签说明中含有各个模板的标签属性可以详细查阅。
可以查看例1-1中的flag='
,这里flag和limit是标签的相关属性,通过手册可以查阅属性的介绍。
如果模板标签如果没有列出属性,系统有默认属性值,用户可以参考模板标签说明查看默认属性。
编程
织梦模板很方便的一个地方就是支持简单的模板编程。
格式为:
tagnamerunphp='
yes'
2$aaa=@me;
3@me="
123456"
;
tagname}
@me表示这个标记本身的值,因此标记内编程是不能使用echo之类的语句的,只能把所有返回值传递给@me。
此外由于程序代码占用了底层模板InnerText的内容,因此需编程的标记只能使用默认的InnerText。
2、代码篇
2.1、common.func.php公用函数
获得当前的脚本网址
functionGetCurUrl()
返回格林威治标准时间
functionMyDate($format='
Y-m-dH:
i:
s'
$timest=0)
把全角数字转为半角
functionGetAlabNum($fnum)
把含HTML的内容转为纯text
functionHtml2Text($str,$r=0)
把文本转HTML
functionText2Html($txt)
输出Ajax头
functionAjaxHead()
中文截取2,单字节截取模式
functioncn_substr($str,$slen,$startdd=0)
把标准时间转为Unix时间戳
functionGetMkTime($dtime)
获得一个0000-00-0000:
00:
00标准格式的时间
functionGetDateTimeMk($mktime)
获得一个0000-00-00标准格式的日期
functionGetDateMk($mktime)
获得用户IP
functionGetIP()
获取拼音以gbk编码为准
functionGetPinyin($str,$ishead=0,$isclose=1)
dedecms通用消息提示框
functionShowMsg($msg,$gourl,$onlymsg=0,$limittime=0)
保存一个cookie
functionPutCookie($key,$value,$kptime=0,$pa="
/"
)
删除一个cookie
functionDropCookie($key)
获取cookie
functionGetCookie($key)
获取验证码
functionGetCkVdValue()
过滤前台用户输入的文本内容
//$rptype=0表示仅替换html标记
//$rptype=1表示替换html标记同时去除连续空白字符
//$rptype=2表示替换html标记同时去除所有空白字符
//$rptype=-1表示仅替换html危险的标记
functionHtmlReplace($str,$rptype=0)
获得某文档的所有tag
functionGetTags($aid)
过滤用于搜索的字符串
functionFilterSearch($keyword)
处理禁用HTML但允许换行的内容
functionTrimMsg($msg)
获取单篇文档信息
functionGetOneArchive($aid)
2.2、dedesql.class.php数据库类
系统会自动载入dedesql.class.php文件,并用
$dsql=$db=newDedeSql(false);
进行初始化数据库连接,因此在工程所有文件中均不需要单独初始化这个类,可直接用$dsql或$db进行操作,为了防止错误,操作完后不必关闭数据库。
常用的方法:
1、执行一个非查询类型的SQL语句,如insert、create、update等
$rs=$db->
ExecuteNoneQuery($sql);
返回值为是否执行成功。
2、执行一个非查询类型的SQL语句,并返回成功记录数
ExecuteNoneQuery2($sql);
与上面相比,它返回的是影响的记录数,而不是布尔值
3、返回单个记录
$arr=$db->
GetOne($sql);
$dsql如果不带limit,系统会自动加上limit0,1
4、执行条件查询语句
1$db->
SetQuery($dsql);
2$db->
Execute();
3while($arr=$db->
GetArray())
4{
5}
可以简化为:
6$db->
Execute('
me'
$dsql);
7while($arr=$db->
8{
9}
'
为记录集游标,用于区分不同的查询,如:
10$db->
11while($arr=$db->
12{
13$db->
2'
$dsql2);
14while($arr2=$db->
15{
16
17}
18}
像这种情况必须指定一个值区分默认的'
参数,否则会出错
$db->
GetArray($rsid,$acctype)参数
$rsid="
me"
$acctype=MYSQL_ASSOC
在查询游标中读取数据还可以用
GetObject($rsid="
);
返回的结果是用类结构表示的值。
5、获取上一个插入的自动递增主键id值
GetLastID();
6、获得查询的总记录数
GetTotalRow($rsid="
7、获得MySql的版本号
GetVersion($isformat=true)
默认的情况下会转换成x.xx形式浮点数
8、析放某查询的资源
FreeResult($rsid="
9、在数据库中是否存在某数据表
IsTable($tbname)
10、重新选择要操作的数据库
SelectDB($dbname);
11、获得数据库连接标识
linkID
获得这个连接标识后,可以直接用mysql相关函数进行数据库操作
在非不得已的情况,项目中一般不使用这个变量。
2.3、datalistcp.class.php动态分页类
类文件
include/datalistcp.class.php
适用范围:
数据量不大的数据分页
使用方法:
1$dl=newDataListCP();
2$dl->
pageSize=25;
//设定每页显示记录数(默认25条)
3$dl->
SetParameter($key,$value);
//设定get字符串的变量
//这两句的顺序不能更换
4$dl->
SetTemplate($tplfile);
?
//载入模板
5$dl->
SetSource($sql);
//设定查询SQL
6
7$dl->
Display();
//显示
模板
8{dede:
datalist}<
9<
li>
{field.fieldname1/}-{field.fieldname2/}...<
/li>
10{/dede:
11<
12{tag:
pagelistlistitem="
info,index,end,pre,next,pageno"
listsize="
5"
/}
listitem、listsize是可选属性
如果需要自定义datalist相关属性,可以继续本类来创建一个新类,只需改变GetArcList($atts,$refObj='
$fields=array())方法即可。
2.4、dedetag.class.php静态模板类
include/dedetag.class.php
这个文件是dedecmsV5.3及之前版本使用的主要的模板类,它是解析式模板类,并非编译式的(区别是前者通过获得标签位置进行内容替换,后者是直接解析式PHP代码,二次执行)
一、模板语法
织梦模板引擎是一种使用XML名字空间形式的模板解析器,使用织梦解析器解析模板的最大好处是可以轻松的制定标记的属性,感觉上就像在用HTML一样,使模板代码十分直观灵活,新版的织梦模板引擎不单能实现模板的解析还能分析模板里错误的标记。
1、织梦模板引擎的代码样式有如下几种形式:
标记名称属性='
值'
}{/dede:
标记名称}
}自定义样式模板(InnerText){/dede:
提示:
如果使用带底层模板的标记,必须严格用{dede:
标记名称}这种格式,否则会报错。
2、织梦模板引擎内置有多个系统标记,这些系统标记在任何场合都是能直接使用的。
(1)global标记,表示获取一个外部变量,除了数据库密码之外,能调用系统的任何配置参数,形式为:
globalname='
变量名称'
global}
或
其中变量名称不能加$符号,如变量$cfg_cmspath,应该写成{dede:
cfg_cmspath'
/}。
(2)foreach用来输出一个数组,形式为:
foreacharray='
数组名称'
}[field:
key/][field:
value/]{/dede:
foreach}
(3)include引入一个文件,形式为:
includefile='
文件名称'
ismake='
是否为dede板块模板(yes/no)'
对文件的搜索路径为顺序为:
绝对路径、include文件夹,CMS安装目录,CMS主模板目录
3、织梦标记允许在任何标记中使用函数对得到的值进行处理,形式为:
function='
fieldname='
pubdate'
4、织梦标记允许有限的编程扩展。
}
$aaa=@me;
@me="
{/dede:
tagname}
二、解析方式
在dedetag.class.php里面有四个类
classDedeAttribute属性结构表述
classDedeAttributeParse属性解析器
classDedeTag标签结构表述
classDedeTagParse标签解析器
使用解析类解析模板时一般经过下面的步骤
1、初始化:
$dtp=newDedeTagParse();
2、载入模板/模板字符串:
$dtp->
LoadTemplate(模板文件(绝对路径));
//会生成缓存,第二次不需解析模板
或$dtp->
LoadSource(字符串);
3、给标签赋值
foreach($dtp->
CTagsas$tid=>
$ctag){
//判断ctag的名称和属性,并给赋不同的值,通常用函数处理
if($ctag->
GetName=='
mytag'
)$dtp->
Assign($tid,mytagvalue($ctag));
}
在上面例子中,直接把名称为mytag的标签转交给mytagvalue函数处理,mytagvalue里判断$ctag的各个属性,返回不同内容即可。
在V5.3版本中,通常除了field、list等专用标签之外,凡arc.*开头的类解析的文件,标签都是对应该include/taglib的源码的,这个由系统进行了自动的映射。
4、显示或保存为HTML
display();
SaveTo(静态文件名);
对于二次开发人员而言,不大需要知道dedecms模板具体解析方式,不过应该十分清楚CTag这个类的结构,从而判断标签不同属性进行处理。
1classDedeTag
2{
3var$IsReplace=FALSE;
//标记是否已被替代,供解析器使用
4var$TagName="
"
//标记名称
5var$InnerText="
//标记之间的文本
6var$StartPos=0;
//标记起始位置
7var$EndPos=0;
//标记结束位置
8var$CAttribute="
//标记属性描述,即是classDedeAttribute
9var$TagValue="
//标记的值
10var$TagID=0;
11
12//获取标记的名称和值
13functionGetName()
14{
15returnstrtolower($this->
TagName);
16}
17
18functionGetValue()
19{
20return$this->
TagValue;
21}
22
23//下面两个成员函数仅是为了兼容旧版
24functionGetTagName()
25{
26returnstrtolower($this->
27}
28
29functionGetTagValue()
30{
31return$this->
32}
33
34//获取标记的指定属性
35functionIsAttribute($str)
36{
37return$this->
CAttribute->
IsAttribute($str);
38}
39
40functionGetAttribute($str)
41{
42return$this->
GetAtt($str);
43}
44
45functionGetAtt($str)
46{
47return$this->
48}
49
50functionGetInnerText()
51{
52return$this->
InnerText;
53}
54}
2.5、dedetemplate.class.php动态模板类
核心类文件
include/dedetemplate.class.php
用途:
用于非核心模块的动态页面或列表页的模板解析,如:
member/content_list.php,通常是在datalistcp.class.php中使用,这个类在动态运行的情况下,由于本身是把模板编译成PHP的
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- DedeCMS 教程 二次开发