Инструменты пользователя

Инструменты сайта


limb3_2007_2:ru:usage:wact:data_containers

Контейнеры данных WACT. Какие данные можно передавать в WACT-шаблоны

Под контейнером данных в WACT шаблоне мы понимаем такой активный компонент откомпилированного шаблона, который предоставляет для остальных доступ к некоторым данным. Контейнеры данных в откомпилированном шаблоне формируют дерево. Это должно быть вам знакомо по материалам разделов:

Различают 2 вида контейнеров данных:

  • Обычный контейнер данных, из которого берутся данные для выражений вида {$title}
  • Списковые контейнеры данных, из которых берутся данных для вывода списков (типичный представитель - тег <list:list>)
  • обычные контейнеры данных обычно называются термином Datasource
  • Списковые контейнеры данных обычно называются итераторами (Iterator) или наборами данных (Dataset).

Обычные контейнеры данных (datasource)

В качестве обычного контейнера данных WACT может использовать следующие объекты:

  • ассоциативный массив
  • объект, который поддерживает интерфейс get()/set() (содержит методы get($field) и set($field, $value))
  • объект, который поддерживает интерфейс ArrayAccess
<core:datasource id='article'>
<h1>{$title}</h1>
{$content}
</core:datasource>
$template = new WactTemplate('my_template.html');
$article = $template->findChild('article');
 
// Вариант 1. Контейнер данных - обычный массив.
$data = array('title' => 'Item1', 'content' => 'Super article');
$article->registerDatasource($data);
 
// Вариант 2. Контейнер данных - объект класса lmbDataspace
$data = new lmbDataspace(array('title' => 'Item1', 'content' => 'Super article'));
$article->registerDatasource($data);
 
// Вариант 3. Контейнер данных - запись из базы данных
$connection = lmbToolkit :: instance()->getDefaultDbConnection();
$stmt = $connection->newStatement('SELECT * FROM item');
$items = $stmt->getRecordSet();
$items->rewind();
$data = $items->current();
$article->registerDatasource($data);

Если в WACT пришел контейнер данных в виде объекта, то он проверяет, поддерживает ли тот методы get. Если да, поддерживает, тогда всегда будет использоваться $datasource→get(’title’) вместо datasource[’title’].

Приоритетность использования интерфейса get()/set() активно используется в пакете WEB_APP для интеграции пакетов ACTIVE_RECORD и WACT. Подробнее об этом см. раздел "Использование ACTIVE_RECORD в шаблонах WACT".

Теги, которым соответствуют обычные контейнеры данных:

Итераторы (dataset)

В качестве источника данных для спискового контейнера данных WACT может использовать обычные массивы, а также любые объекты, которые поддерживают интерфейс итератора (Iterator). Основное условие - чтобы метод current() возвращал нечто, что можно назвать обычным источником данных.

Например:

<list:list id='items'>
<ul>
 <list:item><li>{$title}</li></list:item>
</ul>
</list:list>
$template = new WactTemplate('my_template.html');
$list = $template->findChild('items');
 
// Вариант 1. Контейнер данных - обычный массив.
$data = array(array('title' => 'Item1'),
              array('title' => 'Item2'));
$list->registerDataset($data);
 
// Вариант 2. Контейнер данных - итератор.
$data = new lmbArrayDataset(array(array('title' => 'Item1'), array('title' => 'Item2')));
$list->registerDataset($data);
 
// Вариант 3. Контейнер данных - итератор c данными из базы данных.
$connection = lmbToolkit :: instance()->getDefaultDbConnection();
$stmt = $connection->newStatement('SELECT * FROM item');
$data = $stmt->getRecordSet();
$list->registerDataset($data);

Таким образом WACT может работать одинаково с объектами класса lmbArrayDataset, c объектами lmbMySQLRecordSet и с обычными многомерными массивами.

Мы рекомендуем вам также взглянуть на описание пакета DATASOURCE чтобы ознакомиться с классами, которые используются в Limb в качестве контейнеров данных.

Теги, которым соответствуют списковые контейнеры данных:

Обсуждение

Ваш комментарий. Вики-синтаксис разрешён:
   ____   _  __  ____   _      __ __  __
  / __/  / |/ / / __ \ | | /| / / \ \/ /
 _\ \   /    / / /_/ / | |/ |/ /   \  / 
/___/  /_/|_/  \____/  |__/|__/    /_/
 
limb3_2007_2/ru/usage/wact/data_containers.txt · Последние изменения: 2010/11/10 10:02 (внешнее изменение)