codecamp

Zend Framework 2 模块

模块

Zend Framework 2 使用一个模块系统来组织每个模块内主要的、明确的代码。框架提供的运用程序模块用于提供整个程序的引导、错误和路由配置。应用程序模块通常是用于提供应用界面的控制器,比如说,应用程序的主页,但是在本教程中我们不会使用默认的主页,在生成模块时,我们会将专辑列表设置成主页面。

我们要把所有的代码放到包含控制器、模型、表单和视图,以及配置的 Album 模块当中。我们也要根据需要调整应用程序模块。

从所需要的目录开始吧。

设置 Album 模块

首先在 module 里创建一个名为 Album 的目录,用下面的路径对应保存模块的文件:

zf2-tutorial/
     /module
         /Album
             /config
             /src
                 /Album
                     /Controller
                     /Form
                     /Model
             /view
                 /album
                     /album

正如你所看到的,Album 模块当中有不同类型文件的独立目录。位于 src/Album 目录中包含 Album 名称空间的 PHP 文件,这样的模块就可以设置多个命名空间,这是我们想要的。视图目录也有叫做 album 的子文件夹,用来保存我们的模块视图脚本。

为了安装和配置模块,Zend Framework 2 提供一个 ModuleManager。在模块的根目录(module/Album)寻找 Module.php 文件,可以找到一个叫 module/Album 的类。也就是说,给定目录名称,就会有对应的类模块,有对应的命名空间。

Album 模块创建 Module.php 文件,在 zf2-tutorial/module/Album 创建一个叫 Module.php 的文件,代码如下:

namespace Album;

use Zend\ModuleManager\Feature\AutoloaderProviderInterface;
use Zend\ModuleManager\Feature\ConfigProviderInterface;

class Module implements AutoloaderProviderInterface, ConfigProviderInterface
{
    public function getAutoloaderConfig()
    {
        return array(
            'Zend\Loader\ClassMapAutoloader' => array(
                __DIR__ . '/autoload_classmap.php',
            ),
            'Zend\Loader\StandardAutoloader' => array(
                'namespaces' => array(
                    __NAMESPACE__ => __DIR__ . '/src/' . __NAMESPACE__,
                ),
            ),
        );
    }

    public function getConfig()
    {
        return include __DIR__ . '/config/module.config.php';
    }
}

ModuleManager 将自动调用 getAutoloaderConfig()getConfig() 函数。

自动加载文件

我们的 getAutoloaderConfig() 函数返回一个数组,兼容 ZF2 的 AutoloaderFactory。对它进行配置,添加一个类映射文件给 ClassMapAutoloader 和添加此模块的名称给 StandardAutoloader。标准自动加载需要一个名称空间和在可以找到名称空间文件的路径。与 PSR-0 相兼容,此类按照 PSR-0 规则直接映射到文件。

随着我们开发继续进行,我们不需要通过类映射加载文件,所以我们提供一个空数组给类映射自动加载。在 zf2-tutorial/module/Album 创建一个叫 autoload_classmap.php 的文件:

 return array();

因为这是一个空数组,每当自动加载器在 Album 名称空间中寻找一个类,它都会为我们返回到 StandardAutoloader

注意

如果你使用的是 Composer,你可以只创建一个空的 getAutoloaderConfig(){ } 并添加到 composer.json:

"autoload": {
"psr-0": { "Album": "module/Album/src/" }
},

如果你这样做,那么你需要运行 php composer.phar update 去更新 composer 自动加载文件。

配置

已经注册好自动加载器,让我们来快速地浏览 Album\Module 里面 getConfig() 方法。这个方法简单地加载了 config/module.config.php 文件。

zf2-tutorial/module/Album/config 创建一个叫 module.config.php 的文件:

return array(
     'controllers' => array(
         'invokables' => array(
             'Album\Controller\Album' => 'Album\Controller\AlbumController',
         ),
     ),
     'view_manager' => array(
         'template_path_stack' => array(
             'album' => __DIR__ . '/../view',
         ),
     ),
 );

配置信息通过 ServiceManager 传递给相关的组件。我们需要两个初始部分:控制器和 view_manager。控制器提供了所有由模块提供的控制器列表。我们需要一个控制器 AlbumController,引用作为 Album\Controller\Album。所有控制器的 key 必须是唯一的,所以用模块名称作为前缀。

view_manager 部分,将视图目录添加到 TemplatePathStack 配置中。这样它就可以找到存储在 view/ 目录下的 Album 模块的视图脚本。

给应用程序通知新模块

我们现在需要告诉 ModuleManager 这个新模块的的存在。这个在基本框架应用程序提供的配置 config/application.config.php 文件中完成。更新这个文件,以便他的模块部分包含 Album 模块。因此,文件现在看起来像这样:

(变化需要使用注释突显出来:)

return array(
     'modules' => array(
         'Application',
         'Album',                  // <-- Add this line
     ),
     'module_listener_options' => array(
         'config_glob_paths'    => array(
             'config/autoload/{{,*.}global,{,*.}local}.php',
         ),
         'module_paths' => array(
             './module',
             './vendor',
         ),
     ),
 );

如你所见,在应用程序模块之后,我们已经添加 Album 模块到模块列表当中。

现在设置好模块,准备把自定义代码放到里面。

开始构建一个Zend Framework 2 框架应用程序
Zend Framework 2 路由和控制器
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }