gpt4 book ai didi

php - Zend Framework 2 模块的正确或首选目录结构是什么?

转载 作者:可可西里 更新时间:2023-11-01 12:30:23 27 4
gpt4 key购买 nike

我想通过将 Zend Framework 2 用于一个小项目来掌握它。我浏览了各种博客文章、文档,当然还有 Akrabat (Rob Allen) 的精彩教程。

但是,在我所有的阅读中,我没有遇到任何关于 Zend Framework 2 期望的模块的正确或首选目录结构的解释。

Akrabat tutorial Rob Allen 的示例模块使用单个模型和 Controller 。他选择的目录结构是:

/module
/Album
/config
/src
/Album
/Controller
/Form
/Model
/view
/album
/album

这一切都很好,但是如果一个模块有多个 Controller 和模型,就像您在一个有多个页面/部分的站点中所期望的那样呢?我会把我所有的 Controller 都放在/src/Album/Controller 目录中,还是会为每个额外的模型和相关的 Controller 和 View 创建另一组/src/xxx/目录?

在/view 目录中,我是否将其分解为各个 Controller 使用的每组 View 的子目录?

我认为让我感到困惑的是,在 Rob 的示例中,他的主 Controller /模型与模块同名。所以他的 Album 模块有一个目录,还有更多的 Album 目录用于模型、 Controller 和 View 。如果我将他的模块从 Album 重命名为 MyModule 那么目录结构将变为:

/module
/MyModule
/config
/src
/Album
/Controller
/Form
/Model
/view
/MyModule
/album

那么它会遵循这样组织一个额外的模型,Artist 和关联的 Controller 吗:

/module
/MyModule
/config
/src
/Album
/Controller
/Form
/Model
/Artist
/Controller
/Form
/Model
/view
/MyModule
/album
/artist

如果不是以上,那会是什么结构呢?

当然,这都是假设 ZF2 需要一个严格的结构。如果不是这种情况,那么显然我可以按照我想要的方式组织它。

最佳答案

快速回答您的最后一个问题 - ZF2 确实不关心目录结构。或者我应该说——它没有预定义的结构。这就是它具有自动加载器配置和类映射的原因(取决于您选择使用哪种方法)。

“默认”自动加载器(请参阅 Module.php),您可以在大多数示例中找到它,它仅假定您的 ModuleName 类将在 ./src/ModuleName 中找到。目录:

// ./modules/ModuleName/Module.php
public function getAutoloaderConfig()
{
return array(
'Zend\Loader\StandardAutoloader' => array(
'namespaces' => array(
__NAMESPACE__ => __DIR__ . '/src/' . __NAMESPACE__,
),
),
);
}

我假设您知道这就是那些 __NAMESPACE__部分意思。

因此,如果您有一个名为 Cat 的模块, 它的类应该在 ./modules/Cat/src/Cat 中找到.

如果您随后决定向您的应用程序中添加一些新功能,您将添加另一个名为 Dog 的模块。并将其类文件放在 ./Dog/src/Dog 中.

但是,这绝不意味着您必须这样做。您还可以将所有与动物相关的类(class)放在一个模块中,例如Animals .您必须将自动加载器修改为如下所示:

// ./modules/Animals/Module.php
public function getAutoloaderConfig()
{
return array(
'Zend\Loader\StandardAutoloader' => array(
'namespaces' => array(
'Cat' => __DIR__ . '/src/Cat',
'Dog' => __DIR__ . '/src/Dog',
),
),
);
}

...并将您的类放在类似 ./modules/Animal/src/Cat/Persian.php 的文件中和 ./modules/Animal/src/Dog/Collie.php .

不过,我建议的一件事是将模块视为独立的实体,而不了解其他模块的任何具体信息。作为一个“现实生活”的例子——我有一个应用程序,它有一个前端(html、css 等)和一个 API 功能。

我有 3 个模块:

  • Application - 包含数据库配置、数据库表类、映射器、模型、身份验证类等。基本上是任何其他模块可能需要的所有内容。
  • Api - 让 Controller 期待特定格式的请求并将其输出为例如JSON(即不需要 View )。该模块中的类使用应用程序模块中的类,因为我仍然需要所有数据库功能,但将它们全部分开可以让我将应用程序范围的逻辑与 API 逻辑分开。我可以根据需要撕掉这个模块,它不会破坏其他任何东西。
  • Website - 只负责渲染页面的模块。再一次,它使用应用程序中的类,因为我希望能够从数据库中呈现数据并让用户对其进行编辑,但我不希望只在这个模块中使用该功能,因为 Api 也需要它。

我的 ./config/application.config.php按此顺序加载它们:

return array(
'modules' => array(
'Application',
'Api',
'Website',
),
// all other entries
);

这意味着我可以从所有其他模块访问应用程序类。如果出于某种原因我想禁用我的 API,我只需删除 Api 目录,我的前端仍然可以工作。

希望对您有所帮助! :)

长话短说您可以按照您想要的任何方式构建文件,只是不要忘记正确配置自动加载器。

关于php - Zend Framework 2 模块的正确或首选目录结构是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11863322/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com