Конфигурационные данные передаются конструктору Zend_Config
в виде ассоциативного массива, который может быть многомерным, что
дает возможность организовывать данные от общего к частному. Классы
адаптеров предназначены для того, чтобы преобразовать конфигурационные
данные из хранилища в ассоциативный массив для конструктора
Zend_Config
. Пользовательские скрипты могут также
передавать массивы непосредственно конструктору Zend_Config
без использования класса адаптера, т.к. это может быть наиболее
подходящим решением в некоторых ситуациях.
Каждое значение массива конфигурационных значений становится свойством
объекта Zend_Config
. Ключ массива используется как имя
свойства. Если значение само является массивом, то соответствующее
свойство создается как объект Zend_Config
, который
заполняется данными этого массива. Это производится рекурсивно, т.о.,
иерархия конфигурационных данных может иметь любой уровень вложенности.
Zend_Config
реализует интерфейсы Countable
и Iterator
для того, чтобы обеспечить простой доступ
к конфигурационным данным. Поэтому к объектам
Zend_Config
можно применять функцию
count()
и
такие конструкции языка PHP, как
foreach
.
По умолчанию через Zend_Config
конфигурационные данные
доступны только для чтения, и операция присваивания (например,
$config->database->host = 'example.com'
)
вызовет исключение. Тем не менее, это поведение
может быть отменено при вызове конструктора, и тогда
можно будет изменять конфигурационные данные.
Если модификации разрешены, то также Zend_Config
поддерживает уничтожение значений
(т.е. unset($config->database->host);
).
Замечание | |
---|---|
Важно не путать изменение данных в памяти с сохранением
конфигурационных данных на физическом носителе данных. Создание
и изменение конфигурационных данных на различных
носителях данных не входит в сферу назначений |
Классы адаптеров наследуют от класса Zend_Config
,
и, следовательно, имеют тот же функционал.
Семейство классов Zend_Config
позволяет
организовывать конфигурационные данные, разбивая их на разделы.
В объекты адаптеров Zend_Config
можно загружать
один определенный раздел, несколько разделов или все разделы
данных (если не указан раздел).
Классы адаптеров Zend_Config
поддерживают единую модель
наследования, которая позволяет одному разделу наследовать
конфигурационные данные из другого. Это сделано для того, чтобы
уменьшить или устранить необходимость дублирования конфигурационных
данных разного назначения. Наследующий раздел может замещать данные,
унаследованные от родительского раздела. Как и при наследовании классов PHP,
раздел может наследовать от родительского раздела, который в свою очередь
наследует от другого и т.д., но множественное наследование (т.е. раздел
C наследует напрямую от разделов A и B) не поддерживается.
Если вы имеете два объекта Zend_Config
, то можете объединить
их в один, используя функцию merge()
. Например, имея
$config
и $localConfig
вы можете объединить
данные из $localConfig
с данными из $config
,
используя $config->merge($localConfig);
. Элементы
из $localConfig
при совпадении имен заменят собой элементы
$config
.