许多人在使用过程中都会遇到这样那样的问题,而且zend
framework现在已经到1.11版本了,网络上的很多资料都还停留在旧版本上,因此我在这里以当前的最新版本1.11为例,来简单介绍一下如何使用zend
framework创建模块化的应用程序。由于今后框架的版本升级,有些内容可能会过时,请及时参阅最新的使用手册。
1、准备工作

首先假设你已经部署了web服务器和php,并下载了zend
framework的最新版本,创建了一个最原始的zend
framework项目,并可以访问默认的action了。你可以使用zend
framework工具来创建项目,具体操作参见使用zend
framework创建项目。当然也可以自己手动建立文件夹和文件,参见zend
framework推荐的项目目录结构。

简单地看一下默认的几个重要目录。首先是public,它不但存放了程序的入口点index.php,还可以存放图片,css,javascript文件等。其次是library,用于存放一些类库,包括你自己定义的或第三方的类库。然后是test,用于存放单元测试等测试文件的。最后,也是和我们这里要讲的关系最大的目录——application。进到application目录下,会有以下目录:configs:存放配置文件,一般会有一个主配置文件application.ini;controllers:操制器,如默认的IndexController.php;models:存放业务逻辑,数据模型等文件;views:视图层的脚本,一般以.phtml为后缀名;modules:模块目录,使用工具默认选项自动生成的是没有这个目录的,需要手动添加。modules底下可以包含多个以模块名命名的文件夹,如admin,默认是default,一个文件夹代表一个模块,其下的目录结构与application目录类似,又可以包含controllers,models,views等目录。需要注意的是模块下的controllers下面的文件的类名请加上模块名前缀,如application/modules/admin/controllers/IndexController.php的类名为Admin_IndexController。

如果你需要在项目中方便的使用你自己写的一些类库,或是第三方的类库,可以修改application.ini文件,添加以下行:复制代码 代码如下: autoloaderNamespaces.rockux
= “Rockux_” autoloaderNamespaces.thirdParty = “ThirdPartyLibrary_”
当然你也可以根据需要多添加几个,不过请注意最后面的下划线。
2、建立模块 现在我们来创建一个admin模块,目录如下:
application/modules/admin/controllers application/modules/admin/models
application/modules/admin/views application/modules/admin/views/scripts
application/modules/admin/views/helpers
application/modules/admin/views/filters 并创建以下文件:
application/modules/admin/controllers/IndexController.php(类名为Admin_IndexController)
application/modules/admin/views/scripts/index/index.phtml
除了新建模块文件之外,还需要更改配置文件application.ini,删除以下行,如果有的话:
复制代码 代码如下:
resources.frontController.controllerDirectory =
APPLICATION_PATH”/controllers” 再加上如下行: 复制代码 代码如下:
resources.frontController.moduleDirectory = APPLICATION_PATH “/modules”
resources.frontController.moduleControllerDirectoryName = “controllers”
resources.frontController.defaultModule = “default”
resources.modules[]
这样,再访问
如果我们要充分发挥模块的强大功能,我们还需要为模块添加一个启动文件——Bootstrap.php。它可以使得你在事个模块中方便的使用类资源,models,
filters, helpers等。在admin下新建Bootstrap.php,代码如下: 复制代码 代码如下: class Admin_Bootstrap
extends Zend_Application_Module_Bootstrap { }
并且在application/Bootstrap.php文件里加入以下方法: 复制代码 代码如下: protected function
_initAppAutoload() { $autoloader = new
Zend_Application_Module_Autoloader(array( ‘namespace’ => ‘App’,
‘basePath’ => dirname; return $autoloader; } 复制代码 代码如下: resources.layout.layoutPath
= APPLICATION_PATH “/layouts/scripts” resources.layout.layout =
“layout” admin.resources.layout.layout = “admin”
第二种,不同模块的布局脚本文件分别存放在各自的模块文件夹下
可以在application下新建如下目录和文件:
application/layouts/scripts/layout.phtml
application/modules/admin/layouts/scripts/layout.phtml
在配置文件application.ini中添加如下几行: 复制代码 代码如下: resources.layout.layoutPath
= APPLICATION_PATH “/layouts/scripts” resources.layout.layout =
“layout” admin.resources.layout.layoutPath = APPLICATION_PATH
“/modules/admin/layouts/scripts”
不论是第一种还是第二种,这时如果访问
我们新建文件:library/Rockux/Controller/Action/Helper/LayoutLoader.php,
针对第一种情况代码如下: 复制代码
代码如下: class Rockux_Controller_Action_Helper_LayoutLoader extends
Zend_Controller_Action_Helper_Abstract { public function
preDispatch() { $bootstrap = $this->getActionController()
->getInvokeArg; $config = $bootstrap->getOptions(); $module =
$this->getRequest; if
(isset($config[$module][‘resources’][‘layout’][‘layout’])) {
$layoutScript =
$config[$module][‘resources’][‘layout’][‘layout’];
$this->getActionController() ->getHelper ->setLayout; } } }
针对第二种情况代码如下: 复制代码
代码如下: class Rockux_Controller_Action_Helper_LayoutLoader extends
Zend_Controller_Action_Helper_Abstract { public function
preDispatch() { $bootstrap = $this->getActionController()
->getInvokeArg; $config = $bootstrap->getOptions(); $module =
$this->getRequest; if
(isset($config[$module][‘resources’][‘layout’][‘layoutPath’])) {
$layoutPath =
$config[$module][‘resources’][‘layout’][‘layoutPath’];
$this->getActionController() ->getHelper ->setLayoutPath; } } }
接下来我们还需要将它添加到application/Bootstrap.php里去 复制代码 代码如下: protected function
_initLayoutHelper() { $this->bootstrap; $layout =
Zend_Controller_Action_HelperBroker::addHelper( new
Rockux_Controller_Action_Helper_LayoutLoader; }
再次访问
如果要针对某个特定的controller使用特定的layout,可以在controller的init()方法里添加如下代码:
复制代码 代码如下: $layout =
Zend_Layout::getMvcInstance(); $layout->setLayout;

发表评论

电子邮件地址不会被公开。 必填项已用*标注