destoon二次开发模板及调用语法汇总

一、destoon的目录结构及一些核心的文件

/admin 系统核心后台管理 
├ image         后台风格 
├ template      后台模板 

/api 系统及第三方接口
├ kf            在线客服 
├ map           电子地图 
├ oauth         一键登录 
├ pay           支付接口 
├ stats         第三方统计 
├ trade         担保交易 
├ ucenter       UCenter 

/file
├ backup     数据库备份 
├ cache      缓存 
├ captcha    验证码字体 
├ chat       聊天记录 
├ config     配置 
├ data       导数据导入 
├ email      邮件列表 
├ flash      Flash文件 
├ font       中文字体 
├ image      公用图片 
├ ipdata     IP数据库 
├ log        日志 
├ md5        MD5镜像 
├ mobile     手机列表 
├ script     javascript 
├ session    SESSION 
├ setting    配置数据 
├ temp       临时目录 
├ update     系统更新 
├ upload     上传文件 

/include   核心类库

/install   安装程序

/lang      语言包

/module    功能模块
├ article                  文章模块 
├article/admin             文章管理 
├article/admin/template    文章管理模板
├article/common.inc.php    文章模块初始化
├article/global.func.php   文章核心函数
├article/article.class.php 文章核心类
├article/index.inc.php     文章首页
├article/index.htm.php     静态文章首页
├article/list.inc.php      文章列表页
├ article/list.htm.php     静态文章列表页 
├article/show.inc.php      文章内容页
├article/show.htm.php      静态文章内容页
├article/search.inc.php    文章搜索
├article/task.inc.php      文章计划任务

/skin     风格皮肤
├ default          默认风格 
├default/image     图片文件 
├default/style.css CSS文件

/template 模板文件
├ default          默认模板 
├default/index.htm 首页模板

/upgrade         系统升级

/admin.php       后台入口

/common.inc.php  系统初始化 

/config.inc.php  系统配置 

/index.html      静态首页

/index.php       动态首页

/version.inc.php 版本控制

Destoon也算是mvc框架吧,举个例子

根目录下的文件夹/company里面的文件是MVC中的C,它控制对应module/company中的文件也就是我们说的M,最后我们通过V也是就是tempalte/default/company对应的文件来显示我们的界面,整个流程基本就是这样的。只要把这个流程弄清楚了,其他的就是写代码编程序的问题了。

二、主要的横版模板及调用方法

1.全局标签

网站名称:{$DT[sitename]}
网站地址:{DT_PATH}
网站LOGO:{if$MODULE[$moduleid][logo]}{DT_SKIN}image/logo_{$moduleid}.gif
          {elseif $DT[logo]}{$DT[logo]}{else}{DT_SKIN}image/logo.gif{/if}
版权信息:{$DT[copyright]}
风格路径:{DT_PATH}
客服电话:{$DT[telephone]} 
ICP备案号:{if $DT[icpno]}<a href="http://www.miibeian.gov.cn"
          target="_blank">{$DT[icpno]}</a> ┊ {/if}
VIP会员名称:{VIP}
真实货币名称:{$DT[money_name]}
真实货币单位:{$DT[money_unit]}
虚拟积分名称:{$DT[credit_name]}
虚拟积分单位:{$DT[credit_unit]}
Title(网站标题):{$seo_title}
Meta Keywords(网页关键词):{$head_keywords}
Meta Description(网页描述):{$head_description}

这些全局标签是随时拿出来都可以用的,不仅是在php文件中,在htm文件中也都是可以拿来用的,所以为了快速的、简洁的写代码,这些全局变量我们一定要熟识。

2.连接地址

默认各个模块连接:

会员:{$MODULE[2][linkurl]}   
供应:{$MODULE[5][linkurl]}    
求购:{$MODULE[6][linkurl]}    
行情:{$MODULE[7][linkurl]}      
公司:{$MODULE[4][linkurl]}    
展会:{$MODULE[8][linkurl]}     
资讯:{$MODULE[21][linkurl]}      
招商:{$MODULE[22][linkurl]}     
品牌:{$MODULE[13][linkurl]}  
人才:{$MODULE[9][linkurl]}      
知道:{$MODULE[10][linkurl]}     
专题:{$MODULE[11][linkurl]}   
图库:{$MODULE[12][linkurl]}
视频:{$MODULE[14][linkurl]}
下载:{$MODULE[15][linkurl]}

发布信息:{$MODULE[2][linkurl]}{$DT[file_my]}
企业商铺:{$MODULE[2][linkurl]}home.php
查看站内信:{$MODULE[2][linkurl]}message.php
管理买卖交易:{$MODULE[2][linkurl]}trade.php
完善企业资料:{$MODULE[2][linkurl]}edit.php?tab=2

注册:{$MOD[linkurl]}{$DT[file_register]}
登录:{$MODULE[2][linkurl]}{$DT[file_login]}
找回密码:{$MOD[linkurl]}send.php
VIP页面:{$MODULE[2][linkurl]}grade.php
WAP浏览:{if extend_setting('wap_enable')} <a href="{extendurl('wap')}">WAP浏览</a>{/if}
RSS订阅:{if extend_setting('feed_enable')} | <a href="{extendurl('feed')}">RSS订阅</a>{/if}

行情速递:{$MODULE[7][linkurl]}{rewrite('price.php?product=all')}
企业新闻:{$MODULE[4][linkurl]}{rewrite('news.php?more=1')}
公告:{extendurl('announce')}
推广:{extendurl('spread')}
广告:{extendurl('ad')}
友情链接:{extendurl('link')}
申请友情链接:{extendurl('link')}{rewrite('index.php?action=reg')}
留言本:{extendurl('guestbook')}
投票:{extendurl('vote')}

3.首页调用

导航菜单:

<ul>
<li{if $moduleid<4} class="menuon"{/if}>
    <a href="{DT_PATH}">
        <span>首页</span>
    </a>
</li>
{loop $MODULE $m}
  {if $m[ismenu]}
    <li{if $m[moduleid]==$moduleid} class="menuon"{/if}>
       <a href="{$m[linkurl]}"{if $m[isblank]} target="_blank"{/if}>
            <span{if $m[style]} style="color:{$m[style]};"{/if}>
            {$m[name]}
            </span>
       </a>
    </li>
  {/if}
{/loop}
</ul>

调用登录模块:

  {if $DT[page_login]}
  {template 'user', 'chip'}
  {/if}

调用分类模块:

   {php $mid = 5;}
   {template 'catalog', 'chip'}

4.各个模块数据的调用

供应:
最新供应信息:

1.<!--{tag("moduleid=5&condition=status=3
&length=34&condition=status=3&pagesize=5
&order=addtime desc&template=list-trade")}-->

2.<!--{php $tags=tag("moduleid=5&condition=status=3
&length=34&condition=status=3&pagesize=5
&order=addtime desc&template=null");}-->
{loop $tags $k $t}                                  
<li>
    <span class="f_r">[{area_pos($t[areaid], '/', 1)}]
    </span>
    <a href="{$t[linkurl]}" target="_blank" title="{$t[alt]}">{$t[title]}
    </a>
</li>
{/loop}

标签调用理论上需要网站管理人员有一定的HTML+CSS知识,并对PHP+MySQL有初步的了解。
调用过程实际是按照调用条件从数据表读取调用数量条数据,并依排序方式排序,最终通过标签模板的布局输出数据。
函数原型:tag($parameter, $expires = 0) ,$parameter 表示传递给tag函数的字符串,系统自动将其转换为多个变量 例如传递 table=destoon&pagesize=10,系统相当于得到$table = ‘destoon’$pagesize = 10
两个变量 $expires 表示缓存过期时间。
>0 :缓存$expires秒;
0 :系统默认时间;
-1 :不缓存;
-2 :缓存SQL;
一般情况保持默认即可。
变量 $tags 以数组类型保存标签调用的数据,可通过loop语法遍历显示。
$pages 保存数据分页代码,仅在调用了分页时有效。$path 模块路径。
常用字段:title 标题;linkurl 链接; catid 分类ID;introduce 简介;addtime 添加时间;
常用函数:dsubstr($string, $length, $suffix = ”)将字符串$string截取为$length长,尾部追加$suffix(例如..)
set_style($string, $style = ”, $tag = ‘span’) 将字符串$string置于$tagHTML标签中并设置style为$style
linkurl($linkurl, $absurl =0)将相对路径$linkurl修补为绝对路径(防止链接错误)
date($format, $timestamp)将时间戳$timestamp转化为$format(例如Y-m-d)格式标签

模板: 模板保存于./template/default/tag/目录;建议不要删除或者修改自带的模板,推荐在自带模板基础上新建模板并应用。有时候难免会出现系统自带模版不能满足需求的情况,这时候你可以在此目录下新建一个模版文件,然后按照自己的需求写出自己的模板。

destoon显示地区

显示地区:
需要的函数是
include/module.func.php/get_mainarea($areaid, $area);
php页面:$AREA=cache_read(‘area.php’);//读取缓存文件
静态页面调用:

<table width=”100%” cellpadding=”3″>
{php $mainarea = get_mainarea(0, $AREA)}
{loop $mainarea $k $v}
{if $k%2==0}<tr>{/if}
<td>
    <a href=”{$MOD[linkurl]}
      {rewrite(‘search.php?areaid=’.$v['areaid'].’&typeid=’.$typeid)}”>{$v[areaname]}
    </a>
</td>
{if $k%2==1}</tr>{/if}
{/loop}
</table>
destoon调用分页

分页标签

<!{tag(“moduleid=$moduleid&c=3$dtype&catid=$catid&pagesize=4&page=$page
&showpage=1&datetype=5&order=”.$MOD[order].”&template=list-sell”)}>
# 分页:
{if $showpage && $pages}
    <div class=”pages”>{$pages}
    </div>
{/if}

destoon调用分类
$maincat = get_maincat(0, $CATEGORY);

get_maincat(0, $CATEGORY)  //——在include/global_func.php 中

$childcat = get_maincat(0, $CATEGORY, 1);//— 调用超级栏目下的1级目录

0 代表最最根目录 1代表 level为1的目录level 手动设置 默认都为1
如果0改为3 则为catid 为3 的目录

小注意:
$CATEGORY= cache_read(‘category-’.$moduleid.’.php’);
此文件在模块页的common.inc.php页面中

调用
{loop $maincat $k $v}
{if $k%$DT[page_subcat]==0}<tr>{/if}
<td>
<a
href=”{$MOD[linkurl]}{$v[linkurl]}”>{set_style($v[catname],$v[style])}</a>
<span>({$ITEMS[$v[catid]]})</span>
</td>
{if $k%$DT[page_subcat]==($DT[page_subcat]-1)}</tr>{/if}
{/loop}

注意:
在其模块 module 文件夹下的 php页面里必须有 $maincat
$MOD[linkurl] 是模块也首页地址 $v[linkurl]其下列表页 加catid
标签调用

标签调用是根据调用条件(condition)从数据表(table)读取调用数量(pagesize)条数据,并按排序方式(order)排序,最终通过标签模板的布局输出数据。
可以看出,标签的工作分两个部分,一是读取数据,二是显示数据。
标签函数原型
标签函数保存于 include/tag.func.php
tag($parameter, $expires = 0)
$parameter 表示传递给tag函数的字符串,系统自动将其转换为多个变量
例如传递 table=destoon&pagesize=10&hello=world
系统相当于得到
$table = ‘destoon’; $pagesize = 10; $hello = ‘world’;
三个变量。

数据读取过程

例如以下标签:

<! {tag(“table=sell&c=3&order=addtime desc&pagesize=10″)} ;>

会被转换为如下的SQL语句:

SELECT *
FROM destoon_sell
WHERE status=3
ORDER BY addtime DESC
LIMIT 0,10

读出的数据会保存在 $tags 数组里

数据显示过程

1、通过标签模板显示
传递&template=abc给标签函数,例如:
<! {tag(“table=…&template=abc”)} >
默认的标签模板保存在模板目录/tag/目录里,例如&template=abc将调用模板目录/tag/abc.htm模板来显示数据,如果标签模板放于其他目录,例如def,则传递&dir=def&template=abc,系统将调用模板目录/def/abc.htm模板
2、直接在模板里循环数据
<! {php $tags=tag(“table=…&template=null”);} >
此写法传递标签模板为null,并且直接返回数据给$tags数组,此时可以直接在模板里循环了
以下为一个完整的示例:

<! {php $tags=tag(“table=…&template=null”);} >
{loop $tags $t}
…
{/loop>

第一种写法一般用于多次调用的数据,第二种写法一般用于只调用一次的数据。

常用参数及含义
moduleid指模块ID,可在后台模块管理里查询。对于直接调用模块的数据,设置正确的模块ID后,将不需要传递table参数,系统会自动获取。
例如传递moduleid=5,系统将识别为调用供应信息,自动设置table参数为sell

table指表名,可在后台数据库维护里查询。对于Destoon系统表,不需要加表的前缀;对于非Destoon系统表,需要填写完整的表名,且传递prefix参数
例如对于Destoon系统表,传递table=sell,如果表前缀为destoon_,系统将识别表名为 destoon_sell
对于非Destoon系统表,传递table=tb_abc&prefix=或者table=abc&prefix=tb_,系统将识别表名为 tb_abc

fields指查询的字段,默认为*。可以传递例如 fields=title,addtime,但是一般情况下无需传递,Destoon独有的标签缓存机制会自动缓存查询结果,不必担心效率问题。

condition指查询的条件,如果不传递,则为1,代表任意条件的数据(此项需了解SQL语法)。Destoon所有模块遵循统一标准开发,所以很多条件是通用的。
例如 status=3表示正常通过的信息、status=3 and level=1表示级别为1的信息、status=3 and thumb<>”表示有标题图片的信息等。

order指数据的排序方法(此项需了解SQL语法)。
例如order=addtime desc表示按添加时间降序排列、order=itemid desc表示按itemid降序排列、order=rand()表示随机数据等。

pagesize指调用数据的数量,如果不传递,默认为10。

template指指定的标签模板,如果不传递,默认为list,位于模板目录/tag/list.htm,如果传递为null,表示不应用标签模板。参见上述数据显示过程。

其他常见用法举例

控制标题长度
在标签里传递length参数,例如&length=20表示20个字符长度(GBK一个汉字占2个字符,UTF-8一个汉字占3个字符),一般情况建议用css隐藏多余字符(定义height和overflow:hidden)
传递length参数,系统仅对title字段自动截取,如果需要截取其他字段,可用dsubstr函数
例如 {dsubstr($t[company], 20, ‘…’)} 表示截取company字段为20个字符,截取后,结尾追加…

设置日期显示格式

可以在标签里传递datetype参数:
1 表示年;
2 表示月-日;
3 表示年-月-日;
4 表示月-日 时:分;
5 表示年-月-日 时:分;
6 表示年-月-日 时:分:秒

也可以在模板里直接使用date函数,例如{date(‘Y-m-d’, $t[addtime])}
表示将时间转换为 年-月-日 格式

调用某一分类的信息
在标签里传递catid参数,例如&catid=5表示调用分类ID为5的所有信息。

如果调用多个分类,用逗号分隔分类ID,例如
&catid=5,6,7表示调用分类ID为5、6、7的所有信息。

分类调用默认包含子分类的信息,如果不需要包含子分类,可设置&child=0参数。
例如&catid=5&child=0表示只调用分类ID为5的信息,不包括子分类的信息。

调用某一地区的信息
调用地区信息和上述调用分类信息的方法完全相同,将其中的catid换为areaid即可。

显示信息所在分类

<a
href=”{$MODULE[$moduleid][linkurl]}{$CATEGORY[$t[catid]][linkurl]}”>{$CATEGORY[$t[catid]][catname]}
</a>

控制列数
此项常用于图片的布局,可使用cols参数。
例如调用12张图片,一行显示4个,共3行,则传递&pagesize=12&cols=4

支持cols参数的标签模板限thumb-table.htm和list-table.htm
其中,thumb-table.htm显示图片列表,list-table.htm显示文字列表

如果新建支持cols的标签模板或直接循环$tags,可参考以上两个模板的写法
上述效果可以也可以通过CSS实现,无需使用表格,请自行书写

显示文章的简介
使用{$t[introduce]}变量,如果要截取字数,例如80字符,可使用{dsubstr($t[introduce], 80, ‘…’)}
标签看似复杂难懂,实际上在理解各个参数的含义和调用流程后,您会了解到标签实际简单自由、灵活易用、功能强大。
默认模板里已提供了大量的调用范例和标签模板,可以在学习中参阅和调试。

三、第三方支付接口文件/api

Destoon里面有一个很重要的板块,就是商城板块。有商城就会有交易,而有交易就必须要有一个第三方支付平台,比如支付宝、财付通、网银等等平台。我们就以支付宝为例,你首先需要向支付宝申请一个接口,关于怎么申请支付宝接口百度文库里有一篇文章写得很清楚点这里看文章。有了支付宝接口我们就可以在我们的网站后台设置了。在后台会员管理/模块设置里面选择支付宝。

有一个文档专门讲在线支付配置的可以去看看点这里

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,080评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,422评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,630评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,554评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,662评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,856评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,014评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,752评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,212评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,541评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,687评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,347评论 4 331
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,973评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,777评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,006评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,406评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,576评论 2 349

推荐阅读更多精彩内容

  • DestoonB2B标签调用手册什么是标签调用?标签调用是根据调用条件(condition)从数据表(table)...
    jianghu000阅读 694评论 0 3
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,598评论 18 399
  • 一、destoon的目录结构及一些核心的文件 Destoon也算是mvc框架吧,举个例子 根目录下的文件夹/com...
    layjoy阅读 2,063评论 0 4
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,633评论 18 139
  • 一. Java基础部分.................................................
    wy_sure阅读 3,805评论 0 11