TP下的分组

来源:互联网 发布:葡萄牙红酒淘宝店 编辑:程序博客网 时间:2024/05/16 09:31
ThinkPHP的控制器就是模块类,通常位于项目的LibAction目录下面。类名就是模块名加上Action后缀,例如IndexAction类就表示了Index模块。控制器类必须继承系统的Action基础类,这样才能确保使用Action类内置的方法。


   要启用分组模块非常简单,配置下APP_GROUP_LIST参数和DEFAULT_GROUP参数即可。例如我们把当前的项目分成Home和Admin两个组,分别表示前台和后台功能,那么只需要进行下面的配置:

 

PHP代码

'APP_GROUP_LIST'=>'Admin,Home'

'DEFAULT_GROUP'=>'Home'

 

   需要注意的是,一定要把上面的配置参数放入项目的配置文件,而不是项目的分组配置或者模块配置文件。多个分组之间用逗号分隔即可,默认分组只允许设置一个

 

在我们启用项目分组之前,由于使用的两个项目,所以URL地址分别是:

 

采用分组模式前,URL地址

http:///index.php/Index/index  Home项目地址
http:///Admin/index.php/Index/index  Admin项目地址

 

采用了分组模式后,URL地址变成:

http:///index.php/Home/Index/index
如果Home是默认分组的话 还可以变成 http:///index.php/Index/index
http:///index.php/Admin/Index/index

 

   如果设置了隐藏index.php的话,两者的URL表现效果基本上是一致的,但是从管理和公共调用的角度来看,确实方便了不少。当使用分组模式时,目录结构只是做了一点小小的扩展,主要区别在于项目类库目录模板目录下面多了一层分组目录。

 

1.模块分组

 

   如果不使用分组模式的话,Action目录下面应该是所有的Action类库,现在我们可以在Action目录下面创建自己的分组目录,例如我们把当前项目分成了Home和Admin两个组,那么就需要在Action目录下面创建Home和Admin目录,然后把属于各自的Action类库放到对应的目录下面。如果某个Action类库是每个分组都需要使用或者公共继承的话,可以把这个公共Action类库放到分组目录之外,并且利用ThinkPHP的自动加载机制无需手动引入。

 

使用了模块分组后,如果需要实例化其他分组的模块类,可以使用:
A('Home.User');//实例化Home分组的UserAction类

 

2.模型分组

 

对于分组模式下面的Model类库是否需要分组完全看项目的需要,由于通常不同的分组对应的数据表是相同的,因此,我们推荐Model类库不分组存放,仍然保留之前的方式,无论是什么分组都公共调用Model类库。如果确实需要分组的话,仍然可以按照Action的方式,在Model目录下面创建Home和Admin目录,然后放入对应的Model类库,采用这种方式的话,模型类的调用方法有所区别。

 

如果模型类也分组存放,在使用D方法调用的时候需要使用:
$User = D('Home.User');//实例化Home分组下面的UserModel类

 

3. 模板文件分组

 

模板文件的分组和Action类库分组也基本类似,在原来的模板主题目录下面增加一个分组目录即可。

例如:

Tpl/default/Home/Index/index.html

Tpl/default/Admin/User/index.html

相比之前的模板文件位置就是多了一个分组目录Home和Admin,如果觉得目录结构太深了,可以配置TMPL_FILE_DEPR参数来减少目录层次,该参数默认是 “/”,如果改成

 'TMPL_FILE_DEPR'=>'_'

那么分组的模板文件就变成了

Tpl/default/Home/Index_index.html


Tpl/default/Admin/User_index.html

分组模块的概念,并不局限于将项目区分为前台和后台。你可以按自己所需类型,进行明确细致的区分,这样非常方便于项目管理和开发部署。

分组模块下面的具体模块和之前的模块功能没有任何区别,已有的URL和模块功能都可以很好的支持,例如空模块、空操作、伪静态等等。

0 0
原创粉丝点击