您的位置首页百科问答

DedeCMS V5.8二次开发经验分享

DedeCMS V5.8二次开发经验分享

的有关信息介绍如下:

DedeCMS V5.8二次开发经验分享

DedeCMS V5.3二次开发经验分享

写在前面,DedeCMS系统的模板是非固定的,用户可以在新建栏目时可以自行选择栏目模板,官方仅提供最基本的默认模板,即是内置系统模型的各个模板,由于DedeCMS支持自定义频道模型,用户自定义新频道模型后,还需要按该模型的字段设计一套新的模板,此外,DedeCMS也支持使用风格的形式使用模板,默认风格是 default,它表示系统默认使用 {cmspath}/templets/default 这个文件夹的模板,如果你下载了一套新的模板,你可以不必要删除 default 原有的文件,把下载的模板文件夹命名你想要的风格名称,如 style2 等,然后在后台修改了默认的模板风格名称为 style2 ,那系统将使用{cmspath}/templets/style2 这文件当作默认模板,但是若你手工指定了栏目模板的位置,则后台参数风格的定义无效。

一、概念,设计和使用模板,必须要理解下面几个概念

1、板块(封面)模板:

指网站主页或比较重要的栏目封面频道使用的模板,一般用“index_识别ID.htm”命名,此外,用户单独定义的单个页面或自定义标记,也可选是否支持板块模板标记,如果支持,系统会用板块模板标记引擎去解析后才输出内容或生成特定的文件。

2、列表模板:

指网站某个栏目的所有文章列表的模板,一般用 “list_识别ID.htm” 命名。

3、档案模板:

表示文档查看页的模板,如文章模板,一般用 “article_识别ID.htm” 命名。

4、其它模板:

一般系统常规包含的模板有:主页模板、搜索模板、RSS、JS编译功能模板等,此外用户也可以自定义一个模板创建为任意文件。

二、 命名,DedeCMS模板默认命名规则如下

1、模板保存位置:

模板目录:{cmspath} /templets/样式名称(英文,默认为default,其中system为系统底层模板,plus为插件使用的模板)/具体功能模板文件}

2、 模板文件命名规范:

(1)index_识别ID.htm: 表示板块(栏目封面)模板;

(2)list_识别ID.htm: 表示栏目列表模板;

(3)article_识别ID.htm: 表示内容查看页(文档模板,包括专题查看页);

(4)search.htm: 搜索结果列表模板;

(5)index.htm: 主页模板;

注解:[识别ID]可以在“频道模型管理”的地方获得,当然,你也可以在“频道模型管理”的地方确定某个频道的模板命名。

例:list_image.htm 表示是就是内容类型为图片集的栏目默认列表模板。

article_article.htm 表示的是文章查看页模板。

三、其它模板说明

1、默认底层模板

位置: {cmspath}/templets/system

功能:在没有指定标记的默认底层模板的时候,系统将自动调用这个文件夹的相应文件作为底层模板。

2、插件目录模板

位置: {cmspath}/templets/plus

功能:评论、友情链接、RSS地图等模板。

3、会员后台模板

位置: {cmspath}/member/templets

功能:会员后台的模板。

四、二次开发

在V5.3中已经将标签开发分离出来,您可以通过后台[模板]-[标签代码管理],点击“新增加一个新的标签”来创建一个自己的标签,标签文件名为:标签名.lib.php

接口函数定义为:function lib_标签名(&$ctag,&$refObj),返回值是结果字符串

修改标签时为了防止出错,您也可以修改它的名称(同时修改文件名和函数名),这样等同继承了原来标签的代码建立一个新的标签。

1.2、模板标签语法简介

织梦的模板标签类似于XML格式,所有的模板都含有定界符,默认情况下是{dede:*}和{/dede:*},“*”代表模板标记名称。

一般情况下{dede:*}和{/dede:*}是成对出现的,例如:

例1-1:

1{dede:arclist flag='h' limit='0,1'}

2

[field:title/]


3

[field:description/]...[查看全文]


4{/dede:arclist}

上面的{dede:arclist}和{/dede:arclist}成对出现在模板文件中,并且在两个标签当中包含了底层模板(innertext)。

底层模板(Innertext),底层模板实际上就是对于有多条记录的模板输出,用户手工去指定单个记录的样式。

标签还有一类出现形式是{dede:*/},通常以这种形式出现都是输出变量、或者不含底层模板的内容。

例如:1-2

{dede:global.cfg_webname/}

{dede:arclist flag='h' limit='0,1'/}

如果用户没有指定单个记录的样式,系统部分标签都含有默认的底层模板,具体可以查看{cmapath}/templets/system/文件夹下面的文件,这里面都是系统的底层模板文件。

注释

织梦标签的模板注释非常灵活,可以通过标签后面的commet属性进行赋值。

例1-3:

1{dede:arclist flag='h' limit='0,1' commet='调用头条的第一篇内容'}

2

[field:titlecommet="这是文章标题标签"/]


3

[field:description commet="这是摘要标签"/]...[查看全文]


4{/dede:arclist}

在模板引擎将上述标签解析为html的时候,commet的内容是被忽略掉不去解析的,用户在阅读模板标记的时候可以更好的理解标签的意义。

函数

每一个织梦的标签都可以使用自定义函数对其进行扩展,自定义函数内容主要用于对当前标签输出内容进行处理。

例1-4:

{dede:标记名称function='youfunction("参数一","参数二","@me")'/}

其中 @me 用于表示当前标记的值,其它参数由你的函数决定是否存在,例如:

{dede:field.pubdate function='strftime("%Y-%m-%d %H:%M:%S","@me")'/}

属性

模板标签的属性,决定了模板标记输出的形式,例如arclist标签主要功能是列出文档列表,但列出什么内容、按照什么方式进行排序等取决于模板标签的属性。

在织梦的模板标签说明中含有各个模板的标签属性可以详细查阅。

可以查看例1-1中的flag='h' limit='0,1',这里flag和limit是标签的相关属性,通过手册可以查阅属性的介绍。

如果模板标签如果没有列出属性,系统有默认属性值,用户可以参考模板标签说明查看默认属性。

编程

织梦模板很方便的一个地方就是支持简单的模板编程。

格式为:

1 {dede:tagname runphp='yes'}

2 $aaa = @me;

3 @me = "123456";

4 {/dede:tagname}

@me 表示这个标记本身的值,因此标记内编程是不能使用echo之类的语句的,只能把所有返回值传递给@me。

此外由于程序代码占用了底层模板InnerText的内容,因此需编程的标记只能使用默认的InnerText。

二、代码篇

2.1、common.func.php 公用函数

获得当前的脚本网址

function GetCurUrl()

返回格林威治标准时间

function MyDate($format='Y-m-d H:i:s',$timest=0)

把全角数字转为半角

function GetAlabNum($fnum)

把含HTML的内容转为纯text

function Html2Text($str,$r=0)

把文本转HTML

function Text2Html($txt)

输出Ajax头

function AjaxHead()

中文截取2,单字节截取模式

function cn_substr($str,$slen,$startdd=0)

把标准时间转为Unix时间戳

function GetMkTime($dtime)

获得一个 0000-00-00 00:00:00 标准格式的时间

function GetDateTimeMk($mktime)

获得一个 0000-00-00 标准格式的日期

function GetDateMk($mktime)

获得用户IP

function GetIP()

获取拼音以gbk编码为准

function GetPinyin($str,$ishead=0,$isclose=1)

dedecms通用消息提示框

function ShowMsg($msg,$gourl,$onlymsg=0,$limittime=0)

保存一个cookie

function PutCookie($key,$value,$kptime=0,$pa="/")

删除一个cookie

function DropCookie($key)

获取cookie

function GetCookie($key)

获取验证码

function GetCkVdValue()

过滤前台用户输入的文本内容

// $rptype = 0 表示仅替换 html标记

// $rptype = 1 表示替换 html标记同时去除连续空白字符

// $rptype = 2 表示替换 html标记同时去除所有空白字符

// $rptype = -1 表示仅替换 html危险的标记

function HtmlReplace($str,$rptype=0)

获得某文档的所有tag

function GetTags($aid)

过滤用于搜索的字符串

function FilterSearch($keyword)

处理禁用HTML但允许换行的内容

function TrimMsg($msg)

获取单篇文档信息

function GetOneArchive($aid)

2.2、dedesql.class.php 数据库类

系统会自动载入 dedesql.class.php 文件,并用

$dsql = $db = new DedeSql(false);

进行初始化数据库连接,因此在工程所有文件中均不需要单独初始化这个类,可直接用 $dsql 或 $db 进行操作,为了防止错误,操作完后不必关闭数据库。

常用的方法:

1、执行一个非查询类型的SQL语句,如 insert 、create 、update 等

$rs = $db->ExecuteNoneQuery($sql);

返回值为是否执行成功。

2、执行一个非查询类型的SQL语句,并返回成功记录数

$rs = $db->ExecuteNoneQuery2($sql);

与上面相比,它返回的是影响的记录数,而不是布尔值

3、返回单个记录

$arr = $db->GetOne($sql);

$dsql 如果不带 limit ,系统会自动加上 limit 0,1

4、执行条件查询语句

1$db->SetQuery($dsql);

2$db->Execute();

3while($arr = $db->GetArray())

4{

5}

可以简化为:

6$db->Execute('me',$dsql);

7while($arr = $db->GetArray())

8{

9}

'me' 为记录集游标,用于区分不同的查询,如:

10$db->Execute('me',$dsql);

11while($arr = $db->GetArray())

12{

13 $db->Execute('2',$dsql2);

14 while($arr2 = $db->GetArray())

15 {

16

17 }

18}

像这种情况必须指定一个值区分默认的'me'参数,否则会出错

$db->GetArray($rsid,$acctype) 参数

$rsid="me"

$acctype=MYSQL_ASSOC

在查询游标中读取数据还可以用

$db->GetObject($rsid="me");

返回的结果是用类结构表示的值。

5、获取上一个插入的自动递增主键id值

$db->GetLastID();

6、获得查询的总记录数

$db->GetTotalRow($rsid="me")

7、获得MySql的版本号

$db->GetVersion($isformat=true)

默认的情况下会转换成 x.xx 形式浮点数

8、析放某查询的资源

$db->FreeResult($rsid="me");

9、在数据库中是否存在某数据表

$db->IsTable($tbname)

10、重新选择要操作的数据库

$db->SelectDB($dbname);

11、获得数据库连接标识

$db->linkID

获得这个连接标识后,可以直接用mysql相关函数进行数据库操作

在非不得已的情况,项目中一般不使用这个变量。

2.3、datalistcp.class.php 动态分页类

类文件

include/datalistcp.class.php

适用范围:数据量不大的数据分页

使用方法:

1$dl = new DataListCP();

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

  • {field.fieldname1/} - {field.fieldname2/} ...

  • 10{/dede:datalist}

    11

    12{tag:pagelist listitem="info,index,end,pre,next,pageno" listsize="5"/}

    listitem、listsize 名师在线网www.51mol.com.是可选属性

    如果需要自定义 datalist 相关属性,可以继续本类来创建一个新类,只需改变 GetArcList($atts,$refObj='',$fields=array()) 方法即可。

    2.4、dedetag.class.php 静态模板类

    类文件

    include/dedetag.class.php

    这个文件是dedecms V5.3及之前版本使用的主要的模板类,它是解析式模板类,并非编译式的(区别是前者通过获得标签位置进行内容替换,后者是直接解析式PHP代码,二次执行)

    一、模板语法

    织梦模板引擎是一种使用XML名字空间形式的模板解析器,使用织梦解析器解析模板的最大好处是可以轻松的制定标记的属性,感觉上就像在用HTML一样,使模板代码十分直观灵活,新版的织梦模板引擎不单能实现模板的解析还能分析模板里错误的标记。

    1、织梦模板引擎的代码样式有如下几种形式:

    {dede:标记名称 属性='值'/}

    {dede:标记名称 属性='值'}{/dede:标记名称}

    {dede:标记名称 属性='值'}自定义样式模板(InnerText){/dede:标记名称}

    提示:

    如果使用带底层模板的标记,必须严格用{dede:标记名称 属性='值'}{/dede:标记名称} 这种格式,否则会报错。

    2、织梦模板引擎内置有多个系统标记,这些系统标记在任何场合都是能直接使用的。

    (1) global 标记,表示获取一个外部变量,除了数据库密码之外,能调用系统的任何配置参数,形式为:

    {dede:global name='变量名称'}{/dede:global}

    {dede:global name='变量名称'/}

    其中变量名称不能加 $ 符号,如变量 $cfg_cmspath ,应该写成 {dede:global name='cfg_cmspath'/} 。

    (2) foreach 用来输出一个数组,形式为:

    {dede:foreach array='数组名称'}[field:key/] [field:value/]{/dede:foreach}

    (3) include 引入一个文件,形式为:

    {dede:include file='文件名称' ismake='是否为dede板块模板(yes/no)'/}

    对文件的搜索路径为顺序为:绝对路径、include文件夹,CMS安装目录,CMS主模板目录

    3、织梦标记允许在任何标记中使用函数对得到的值进行处理,形式为:

    {dede:标记名称 属性='值' function='youfunction("参数一","参数二","@me")'/}

    其中 @me 用于表示当前标记的值,例如易码网www.yimain.com其它参数由你的函数决定是否存在,例如:

    {dede:field name='pubdate' function='strftime("%Y-%m-%d %H:%M:%S","@me")'/}

    4、织梦标记允许有限的编程扩展。

    格式为:

    {dede:tagname runphp='yes'}

    $aaa = @me;

    @me = "123456";

    {/dede:tagname}

    @me 表示这个标记本身的值,因此标记内编程是不能使用echo之类的语句的,只能把所有返回值传递给@me。

    此外由于程序代码占用了底层模板InnerText的内容,因此需编程的标记只能使用默认的InnerText。

    二、解析方式

    在 dedetag.class.php 里面有四个类

    class DedeAttribute 属性结构表述

    class DedeAttributeParse 属性解析器

    class DedeTag 标签结构表述

    class DedeTagParse 标签解析器

    使用解析类解析模板时一般经过下面的步骤

    1、初始化:

    $dtp = new DedeTagParse();

    2、载入模板/模板字符串:

    $dtp->LoadTemplate(模板文件(绝对路径)); //会生成缓存,第二次不需解析模板

    或$dtp->LoadSource(字符串);

    3、给标签赋值

    foreach($dtp->CTags as $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

    $dtp->display();

    $dtp->SaveTo(静态文件名);

    对于二次开发人员而言,不大需要知道dedecms模板具体解析方式,不过应该十分清楚CTag这个类的结构,从而判断标签不同属性进行处理。

    2.5、dedetemplate.class.php 动态模板类

    核心类文件

    include/dedetemplate.class.php

    用途:用于非核心模块的动态页面或列表页的模板解析,如:member/content_list.php ,通常是在 datalistcp.class.php 中使用,这个类在动态运行的情况下,由于本身是把模板编译成PHP的,因此性能上会优级于旧的解析类,这个方法将在未来版本中作为通用的方式。

    $tpl = new DedeTemplate(

    模板对象实例名称,通常是'tpl',

    [模板存放目录(生成缓存时会存放在这个目录),

    include语法默认引用目录]

    );

    通常情况下参数二和参数三是不必要的,如:$tpl = new DedeTemplate('tpl');

    如果在类文件中调用,应该加上设置:$this->tpl->SetObject($this);

    在一些块调用中默认将使用当前类的成员函数。$tpl->LoadTemplate(模板的物理路径);

    如果模板中带有 {dede:config name='' value=''/}例如服装之家www.fzzjia.com可以在载入模板后,通过 $tpl->GetConfig($name) 获得这些变量的值。显示页面或保存页面为文件$tpl->Display();$tpl->SaveTo(物理绝对路径的文件名);

    4.1、自定义模型使用教程

    在织梦系统中有内容模型这个概念,不同内容模型可以用来构建不同内容形式的站点,在系统中自带了以下几种模型:普通文章、图集、软件、商品、分类信息、专题。通过系统自带的模型,我们可以用来构建不同类型的站点,例如:使用图集可以做一个图片站,用软件模型构建一个软件下载站点。

    当然以上随系统附带的模型被称为系统模型,用户可以自己定义一些模型,比如图书、音乐专辑等,自定义了这些模型才可以构建更多内容形式的站点,本篇将讲述如何使用系统的自定义模型管理功能来实现内容模型的构建。

    我们首先登录系统后台,点击[核心]-[内容模型管理],进入内容模型管理界面,如下图所示:

    这里我们介绍几个相关参数的概念:

    •ID号 用于区分模型的唯一ID,一般常规模型的ID都是大于0的,比如普通文章、软件等,如果使用了单表模型,ID一般需要小于-1,例如这里的分类信息模型;

    •频道名称 用于识别频道类型的标识;

    •识别id 系统用于识别的id,这个关系到模板方面;

    •附加表 系统内容附加表项;

    •模型类型 分为系统类型和自动类型,系统类型为固化在系统中的内容模型,自动类型为用户可创建的内容模型类型;

    接下来我们开始介绍如何使用自定义模型管理来创建一个自己的模型,并且用于建设不同内容类型的网站中去。

    这里我们介绍一些周边的内容,几个要用到的概念:

    •字段 在数据库中,表的列称为字段,织梦系统也是如此,但更恰当的说法,存储某个内容信息单元,称为字段,例如标题、来源、作者等都是一个字段;

    •内容系统主表 程序将一些公用字段存储在系统主表dede_archives,例如:标题、关键词、缩略图等,主表具体字段可以查询织梦帮助中心(http://help.dedecms.com)的有关二次开发手册数据表部分的内容;

    •附加表 不同内容模型对应不同的附加表,通常以dede_addon[识别ID]命名,附加表中存放的都是详细内容的相关字段(非公用),例如:文章内容(dede_addonarticle)、软件类型(dede_addonsoft)、图片集合(dede_addonimage)等;

    •单表独立模型 存储时候不用到“主表+附加表”的结构形式,直接使用单个数据表进行存储内容数据,这样脱离主从表,减少主表数据服在开销,可以从很大程度上解决数据负载问题;

    明白了以上几个概念我们可以来学习如何来自己创建一个内容模型了。

    一个完整的内容模型包含模型数据表、数据字段、模型模板、模型参数4个部分,制作一个内容模型大致有以下几个步骤:1.模型规划;2.模型制作;3.模板制作;4.栏目设置,下面我们从上面4个步骤来讲解内容模型的制作。这里我们以一个图书模型(book)为例子,这个模型主要功能就是介绍书籍。

    因为介绍一本书,我们规划了以下内容:

    出 版 社publish单行文本(varchar)

    出版时间pubtime时间类型

    字  数cnum整数类型

    版  次pubnum整数类型

    页  数pagenum整数类型

    印刷时间pritime时间类型

    开  本kbook单行文本(varchar)

    印  次prinum整数类型

    纸  张pages单行文本(varchar)

    I S B Nisbn单行文本(varchar)

    包  装packs单行文本(varchar)

    内容简介bodyHTML文本

    作者简介wrbodyHTML文本

    目录bindexHTML文本

    这样,我们完成了第一步模型的规划。

    模型制作

    规划完成了,接下来我们开始将这些规划的内容创建为一个内容模型。首先以超级管理员身份登录到系统后台。点击[核心]-[模型管理],点击“增加新模型”按钮来创建模型。

    按照系统提示配置模型的基本信息,这里因为选择的是自动模型,所以档案发布的相管程序页面只需要保留默认即可。因为我们发布的是图书,所以这里“投稿标题使用名称”设置为:图书名称。

    因为这里我们使用的是自动模型,没有自己制作相应的发布管理程序,所以下面的相关模型发布程序保持默认即可,当然如果你有一定的编程能力,可以自己制作一个内容发布程序,然后在这里指定即可。

    基本信息设置完毕,直接单击确定即可,进入到字段管理的页面,点击字段管理中的“添加新字段”按钮,进入字段添加页面,我们根据相关的字段信息进行字段添加。

    下面是一些字段类型我们对部分字段进行一些说明:

    单行文本(varchar):常用字段,如文章标题、作者等都属于直接输入少量内容的文本,设置这个文本之后需要指定文本长度,默认为250,如果大于255则为text类型

    多行文本:也是较为常用的字段类型,如个人简介、产品描述都可以使用多行文本进行存储

    HTML文本:用织梦编辑器编辑产生的html内容,用于比较复杂的内容形式

    附件类型:可以后台上传附件让用户下载,附件类型可以在后台进行设置

    option下拉框:下拉选择,一般用于如软件类型、语言类型等字段

    联动类型:一种数组形式的数据类型,可以在系统后台联动类型管理中进行设置

    了解了这些字段类型我们就可以添加我们的字段信息了。

    添加完成点击确定即可,这样我们就完成了这个模型的制作。模型添加完毕之后我们发现在内容发布的地方多出来一个发布图书的选项,这个说明我们的模型就已经成功添加了。

    模板制作

    我们通过织梦帮助中心的《主要模板文件与功能说明》了解到每个模型还需要制作对应的模型模板文件,我们可以通过后台模型管理中的模板文件说明查看模板文件。

    模板制作主要有2个地方需要讲解下。

    1. 列表页模板list_[识别ID].htm中显示在列表中需要调用添加扩展的字段需要在添加字段页面勾选“使字段可以在列表的底层模板中获得(自定义字段默认仅能在文档模板显示,启用此选项将使列表查询变慢,如无必要请不要选择)”,这样在{dede:list/}标签中就可以使用[field:fieldname/]来进行调用。

    2. 内容页的标签可以使用{dede:field.fieldname /} 进行调用,具体可以参考帮助中心模板相关的帮助文档。

    栏目设置

    接下来我们就可以来添加一个栏目,在栏目设置中将栏目的内容模型设置为图书

    然后我们就可以在这个栏目下添加文档,会发现我们现在可以发布图书内容了

    添加完成之后,我们可以浏览我们的网站页面,预览我们的模型效果。

    至此我们完成了整个模型的制作,整个过程还是非常简单的。这里只介绍了自动模型的制作,当然有一定PHP基础的用户可以自己开发系统模型,这样就会拥有更为强大的织梦系统,使得网站内容更加丰富。

    4.2、联动类别使用说明教程

    织梦在新版本V5.3中加入了一个联动类别的功能,不少人不理解这个联动类别的使用方法,本教程天涯就来介绍如何使用这个功能。

    联动类别使用的地方还是比较多的,首先我们可以通过后台的[核心]-[频道模型]-[联动类别管理]查看,联动类别其定义如下:系统一种特殊的枚举数据类别,可以有系统内置或由用户管理。系统内置的枚举用户是不可以删除的,但可以对这些数据进行添加子分类及修改。到这里可能一些用户还是不了解什么是联动类型,下面我们举几个简单的例子。

    一个最简单的联动类型是只有一级选择的类型,比如说系统内置的星座、教育程度、血型,这种类型你可以点击进去查看,其结构很简单,例如星座(star):

    在这个联动类别中级数为“一级选择”,就是在这个星座类别下面只有一列品级数据进行选择,我们点击进去可以查看到以内容:

    这个让我们很容易联想到许多网站中设置用户资料的时候,需要用户选择星座,我们就可以通过一个下拉框进行选择:

    当然,上面说到的是最简单的联动类别,只有一级联动,这种一级联动就可以好比是一个下拉框,用户在选择具体数据的时候只要通过下拉框这种形式就可以对数据进行选择。但是我们在很多联动数据中遇到不少需要二级联动的类型,例如我们在资料设置中选择“所在城市”这个类别,如下图所示

    这种数据类型就属于需要选择2次分类,首先选择上海市,然后列出上海市拥有的地区,然后再进行第二次选择,这就是一个二级联动的类别,我们可以通过系统后台查看联动类别中的地区来看看系统的枚举类型。

    通过以上2个例子我们不难理解联动类型的概念,其实说简单了就是一种特殊的枚举数据类型,这种特殊的枚举类型运用在创建内容模型、用户资料等数据录入的页面中,其中应用在创建模型及用户自定义表单是联动类别最常用的地方,下面我们来介绍如何使用这个联动模型。

    我们以创建一个“图书(book)”内容模型为例,这个模型中我们需要网站管理员(用户)提交一个图书特征的分类,我们知道以下图书特征的分类:

    线装书,精装书,平装书,袋装书,电子书,有声读物,盲人书

    下面我们就创建一个这个一级选择的枚举类型,这个类型叫图书特征(bookfeature),我们点击“新增类别组”来创建分类。

    创建完成后我们将类别的内容全部添加到这个类别中去,在页面中提示我们如果一次性添加多个类别可以用“,”将不同类别隔开,然后一次性添加。

    这样我们就创建完成了这个图书特征(bookfeature)的联动类型,接下来我们要应用这个联动类型,我们在新创建的模型中添加字段,在字段添加的页面中添加相应的字段名称,选择数据类型为联动类型,如下图所示:

    在我们发布图书内容的时候,就会发现有一个选择是图书特征的内容类型选择,不过个人建议如果设计一级联动选择,最好还是使用“option下拉框”这个数据类型。

    使用同样的字段设置方法也可以添加其他二级联动的字段,这个我们可以查看“分类信息”这个模型里面的联动类型数据。

    当然我们在系统的自定义表单中也可以使用这个联动类型,使用的方法和模型管理里面添加字段是一样的,这里就不再重复了。当然,在二次开发中也会遇到在一些页面调用这些枚举的列表,可以查看/include/enums.func.php第61行GetEnumsForm这个函数,具体的使用可以参考下会员中心编辑用户信息这个页面文件的方法,具体文件为/member/templets/ edit_info_person.htm。

    枚举类型在模型制作和系统开发中用到的地方还是比较多的,大家可以有空的时候进行一些研究,会发现更多关于联动类型的应用方法,不要忘记分享哦。