配置(Configurations)

在 Yii 中,创建新对象和初始化已存在对象时广泛使用配置。
配置通常包含被创建对象的类名和一组将要赋值给对象
属性的初始值。
还可能包含一组将被附加到对象事件上的句柄。
和一组将被附加到对象上的行为

以下代码中的配置被用来创建并初始化一个数据库连接:

  1. $config = [
  2. 'class' => 'yii\db\Connection',
  3. 'dsn' => 'mysql:host=127.0.0.1;dbname=demo',
  4. 'username' => 'root',
  5. 'password' => '',
  6. 'charset' => 'utf8',
  7. ];
  8. $db = Yii::createObject($config);

[[Yii::createObject()]] 方法接受一个配置数组并根据数组中指定的类名创建对象。
对象实例化后,剩余的参数被用来初始化对象的属性,
事件处理和行为。

对于已存在的对象,可以使用 [[Yii::configure()]] 方法根据配置去初始化其属性,
就像这样:

  1. Yii::configure($object, $config);

请注意,如果配置一个已存在的对象,那么配置数组中不应该包含指定类名的 class 元素。

" class="reference-link">配置的格式(Configuration Format)

一个配置的格式可以描述为以下形式:

  1. [
  2. 'class' => 'ClassName',
  3. 'propertyName' => 'propertyValue',
  4. 'on eventName' => $eventHandler,
  5. 'as behaviorName' => $behaviorConfig,
  6. ]

其中

  • class 元素指定了将要创建的对象的完全限定类名。
  • propertyName 元素指定了对象属性的初始值。键名是属性名,值是该属性对应的初始值。
    只有公共成员变量以及通过 getter/setter 定义的
    属性可以被配置。
  • on eventName 元素指定了附加到对象事件上的句柄是什么。
    请注意,数组的键名由 on 前缀加事件名组成。
    请参考事件章节了解事件句柄格式。
  • as behaviorName 元素指定了附加到对象的行为
    请注意,数组的键名由 as 前缀加行为名组成。$behaviorConfig
    值表示创建行为的配置信息,格式与我们之前描述的配置格式一样。

下面是一个配置了初始化属性值,事件句柄和行为的示例:

  1. [
  2. 'class' => 'app\components\SearchEngine',
  3. 'apiKey' => 'xxxxxxxx',
  4. 'on search' => function ($event) {
  5. Yii::info("搜索的关键词: " . $event->keyword);
  6. },
  7. 'as indexer' => [
  8. 'class' => 'app\components\IndexerBehavior',
  9. // ... 初始化属性值 ...
  10. ],
  11. ]

" class="reference-link">使用配置(Using Configurations)

Yii 中的配置可以用在很多场景。本章开头我们展示了如何使用 [[Yii::creatObject()]]
根据配置信息创建对象。本小节将介绍配置的两种
主要用法 —— 配置应用与配置小部件。

" class="reference-link">应用的配置(Application Configurations)

应用的配置可能是最复杂的配置之一。
因为 [[yii\web\Application|application]] 类拥有很多可配置的属性和事件。
更重要的是它的 [[yii\web\Application::components|components]]
属性可以接收配置数组并通过应用注册为组件。
以下是一个针对基础应用模板的应用配置概要:

  1. $config = [
  2. 'id' => 'basic',
  3. 'basePath' => dirname(__DIR__),
  4. 'extensions' => require __DIR__ . '/../vendor/yiisoft/extensions.php',
  5. 'components' => [
  6. 'cache' => [
  7. 'class' => 'yii\caching\FileCache',
  8. ],
  9. 'mailer' => [
  10. 'class' => 'yii\swiftmailer\Mailer',
  11. ],
  12. 'log' => [
  13. 'class' => 'yii\log\Dispatcher',
  14. 'traceLevel' => YII_DEBUG ? 3 : 0,
  15. 'targets' => [
  16. [
  17. 'class' => 'yii\log\FileTarget',
  18. ],
  19. ],
  20. ],
  21. 'db' => [
  22. 'class' => 'yii\db\Connection',
  23. 'dsn' => 'mysql:host=localhost;dbname=stay2',
  24. 'username' => 'root',
  25. 'password' => '',
  26. 'charset' => 'utf8',
  27. ],
  28. ],
  29. ];

配置中没有 class 键的原因是这段配置应用在下面的入口脚本中,
类名已经指定了。

  1. (new yii\web\Application($config))->run();

更多关于应用 components 属性配置的信息可以查阅应用
以及服务定位器章节。

自版本 2.0.11 开始,系统配置支持使用 container 属性来配置依赖注入容器
例如:

  1. $config = [
  2. 'id' => 'basic',
  3. 'basePath' => dirname(__DIR__),
  4. 'extensions' => require __DIR__ . '/../vendor/yiisoft/extensions.php',
  5. 'container' => [
  6. 'definitions' => [
  7. 'yii\widgets\LinkPager' => ['maxButtonCount' => 5]
  8. ],
  9. 'singletons' => [
  10. // 依赖注入容器单例配置
  11. ]
  12. ]
  13. ];

请参考 依赖注入容器 下面的 高级应用实例
获取更多 definitionssingletons 配置项和实际使用的例子。

" class="reference-link">小部件的配置(Widget Configurations)

使用小部件时,常常需要配置以便自定义其属性。
[[yii\base\Widget::widget()]] 和 [[yii\base\Widget::begin()]] 方法都可以用来创建小部件。
它们可以接受配置数组:

  1. use yii\widgets\Menu;
  2. echo Menu::widget([
  3. 'activateItems' => false,
  4. 'items' => [
  5. ['label' => 'Home', 'url' => ['site/index']],
  6. ['label' => 'Products', 'url' => ['product/index']],
  7. ['label' => 'Login', 'url' => ['site/login'], 'visible' => Yii::$app->user->isGuest],
  8. ],
  9. ]);

上述代码创建了一个小部件 Menu 并将其 activateItems 属性初始化为 false。
item 属性也配置成了将要显示的菜单条目。

请注意,代码中已经给出了类名 yii\widgets\Menu,配置数组不应该再包含 class 键。

" class="reference-link">配置文件(Configuration Files)

当配置的内容十分复杂,通用做法是将其存储在一或多个 PHP 文件中,
这些文件被称为配置文件。一个配置文件返回的是 PHP 数组。
例如,像这样把应用配置信息存储在名为 web.php 的文件中:

  1. return [
  2. 'id' => 'basic',
  3. 'basePath' => dirname(__DIR__),
  4. 'extensions' => require __DIR__ . '/../vendor/yiisoft/extensions.php',
  5. 'components' => require __DIR__ . '/components.php',
  6. ];

鉴于 components 配置也很复杂,上述代码把它们存储在单独的 components.php 文件中,并且包含在 web.php 里。
components.php 的内容如下:

  1. return [
  2. 'cache' => [
  3. 'class' => 'yii\caching\FileCache',
  4. ],
  5. 'mailer' => [
  6. 'class' => 'yii\swiftmailer\Mailer',
  7. ],
  8. 'log' => [
  9. 'class' => 'yii\log\Dispatcher',
  10. 'traceLevel' => YII_DEBUG ? 3 : 0,
  11. 'targets' => [
  12. [
  13. 'class' => 'yii\log\FileTarget',
  14. ],
  15. ],
  16. ],
  17. 'db' => [
  18. 'class' => 'yii\db\Connection',
  19. 'dsn' => 'mysql:host=localhost;dbname=stay2',
  20. 'username' => 'root',
  21. 'password' => '',
  22. 'charset' => 'utf8',
  23. ],
  24. ];

仅仅需要 “require”,就可以取得一个配置文件的配置内容,像这样:

  1. $config = require 'path/to/web.php';
  2. (new yii\web\Application($config))->run();

" class="reference-link">默认配置(Default Configurations)

[[Yii::createObject()]] 方法基于依赖注入容器实现。
使用 [[Yii::creatObject()]] 创建对象时,可以附加一系列默认配置到指定类的任何实例。
默认配置还可以在入口脚本
中调用 Yii::$container->set() 来定义。

例如,如果你想自定义 [[yii\widgets\LinkPager]] 小部件,以便让分页器最多只显示 5 个翻页按钮(默认是 10 个),
你可以用下述代码实现:

  1. \Yii::$container->set('yii\widgets\LinkPager', [
  2. 'maxButtonCount' => 5,
  3. ]);

不使用默认配置的话,你就得在任何使用分页器的地方,
都配置 maxButtonCount 的值。

" class="reference-link">环境常量(Environment Constants)

配置经常要随着应用运行的不同环境更改。例如在开发环境中,
你可能使用名为 mydb_dev 的数据库,
而生产环境则使用 mydb_prod 数据库。
为了便于切换使用环境,Yii 提供了一个定义在入口脚本中的 YII_ENV 常量。
如下:

  1. defined('YII_ENV') or define('YII_ENV', 'dev');

你可以把 YII_ENV 定义成以下任何一种值:

  • prod:生产环境。常量 YII_ENV_PROD 将被看作 true。
    如果你没修改过,这就是 YII_ENV 的默认值。
  • dev:开发环境。常量 YII_ENV_DEV 将被看作 true。
  • test:测试环境。常量 YII_ENV_TEST 将被看作 true。

有了这些环境常量,你就可以根据当下应用运行环境的不同,进行差异化配置。
例如,应用可以包含下述代码只在开发环境中开启
调试工具

  1. $config = [...];
  2. if (YII_ENV_DEV) {
  3. // 根据 `dev` 环境进行的配置调整
  4. $config['bootstrap'][] = 'debug';
  5. $config['modules']['debug'] = 'yii\debug\Module';
  6. }
  7. return $config;