Mercurial > pub > Impl
comparison Lib/IMPL/Web/View/TTDocument.pm @ 195:7a920771fd8e
IMPL::Web::View changed document layout handling, docs, examples
author | cin |
---|---|
date | Wed, 11 Apr 2012 17:50:33 +0400 |
parents | 4d0e1962161c |
children | 292226770180 |
comparison
equal
deleted
inserted
replaced
194:4d0e1962161c | 195:7a920771fd8e |
---|---|
115 | 115 |
116 my $output; | 116 my $output; |
117 | 117 |
118 if ($this->layout) { | 118 if ($this->layout) { |
119 $output = $this->context->include( | 119 $output = $this->context->include( |
120 $this->loader->template($this->layout), | 120 $this->loader->layout($this->layout), |
121 { | 121 { |
122 content => sub { $output ||= $this->RenderContent($args); }, | 122 content => sub { $output ||= $this->RenderContent($args); }, |
123 this => $this, | 123 this => $this, |
124 template => $this->template | 124 template => $this->template |
125 } | 125 } |
180 Процесс форматирования объектной модели в готовый документ может быть выполнена как вручную, так и при помощи | 180 Процесс форматирования объектной модели в готовый документ может быть выполнена как вручную, так и при помощи |
181 вспомогательного шаблона - обертки. Если у шаблона документа указан C<layout> в метаданных, то он будет | 181 вспомогательного шаблона - обертки. Если у шаблона документа указан C<layout> в метаданных, то он будет |
182 использован как шаблон для форматирования объектной модели, вывод самого шаблона будет проигнорирован. Если | 182 использован как шаблон для форматирования объектной модели, вывод самого шаблона будет проигнорирован. Если |
183 обертка не задана, то результатом будет вывод самого скрипта шаблона. | 183 обертка не задана, то результатом будет вывод самого скрипта шаблона. |
184 | 184 |
185 Использование объектной модели документа позволяет решить задачи по созданию элементов управления | 185 Использование объектной модели документа позволяет решить задачи по созданию контейнеров, |
186 контейнеров, у которых может быть сложное содежимое. Примером таких элементов могут быть формы, | 186 у которых может быть сложное содежимое. Примером таких элементов могут быть формы, |
187 внутри форм элементы управления могут группироваться. | 187 внутри форм элементы управления также могут группироваться. |
188 | 188 |
189 =head2 Элементы управления (компоненты) | 189 =head2 Элементы управления (компоненты) |
190 | 190 |
191 Документ состоит из узлов, часть которых наследуется от C<IMPL::Web::View::TTControl>, такие узлы называются | 191 Документ состоит из узлов, часть которых наследуется от C<IMPL::Web::View::TTControl>, такие узлы называются |
192 элементами управления. Каждый элемент управления имеет собственный контекст, который наследуется от контекста | 192 элементами управления. Каждый элемент управления имеет собственный контекст, который наследуется от контекста |
196 | 196 |
197 Для создания элементов управления используются фабрики. Каждый элемен управления имеет свой шаблон для | 197 Для создания элементов управления используются фабрики. Каждый элемен управления имеет свой шаблон для |
198 форматиорвания содержимого, фабрика связывает шаблон и класс элемента управления, для чего при загрузке | 198 форматиорвания содержимого, фабрика связывает шаблон и класс элемента управления, для чего при загрузке |
199 шаблона используется свойство C<type> из метаданных. Фабрика загружается в документ при том только один | 199 шаблона используется свойство C<type> из метаданных. Фабрика загружается в документ при том только один |
200 раз, повторные загрузки фабрики возвращают уже загруженную. Для загрузки фабрики используется метод | 200 раз, повторные загрузки фабрики возвращают уже загруженную. Для загрузки фабрики используется метод |
201 C<require()>. | 201 C<require()> с указанием элемента управления. |
202 | |
203 | 202 |
204 =head2 Порядок обработки документа | 203 =head2 Порядок обработки документа |
205 | 204 |
206 =over | 205 Построение представления данных состоит из двух этапов |
207 | 206 |
208 =item 1 Создается документ при помощи метода C<TTLoader::document()> | 207 =over |
209 | 208 |
210 =item 1 При создании документа (в конструкторе), происходит выполнение блока C<CTOR> | 209 =item 1 Создание объектной модели документа. На данном этапе создаются все элементы управления. |
211 | 210 |
212 =item 1 При вызове метода C<TTDocument::Render()> устанавливаются переменные C<this>, C<document> | 211 =item 1 Преобразование объектной модели в конечнное представление. На данном этапе происходит |
213 и шаблон обрабатывается при помощи метода C<process()> контекста документа. | 212 форматирование документа. |
214 | 213 |
215 =back | 214 =back |
215 | |
216 | 216 |
217 =head2 Загрузка элемента управления | 217 =head2 Загрузка элемента управления |
218 | 218 |
219 =over | 219 =over |
220 | 220 |
221 =item 1 C<TInput = require('my/org/input')> | 221 =item 1 C<TInput = require('my/org/input')> |
222 | 222 |
223 =item 1 Загружает шаблон C<my/org/input.tt> | 223 =item 1 Загружается шаблон C<my/org/input.tt> |
224 | 224 |
225 =item 1 Создает фабрику элементов управления с собственным контекстом, унаследованным от контекст документа. | 225 =item 1 Создается фабрика элементов управления с собственным контекстом, унаследованным от контекст документа. |
226 | 226 |
227 =item 1 Выполняет шаблон в пространстве имен фабрики | 227 =item 1 При первом создании элемента управления фабрика инициализируется выполнением блока C<INIT>. |
228 | 228 |
229 =back | 229 =back |
230 | 230 |
231 =head2 Создание элемента управления | 231 =head2 Создание элемента управления |
232 | 232 |
233 =over | 233 =over |
234 | 234 |
235 =item 1 C<< TInput.new('login') >> | 235 =item 1 C<< TInput.new('login') >> |
236 | 236 |
237 =item 1 Если это первый элемент управления, то выполняетя статический конструктор в контексте фабрики | |
238 | |
239 =item 1 Создается новый дочерний контекст к контексту фабрики | 237 =item 1 Создается новый дочерний контекст к контексту фабрики |
240 | 238 |
241 =item 1 Создается экземпляр элемента управления | 239 =item 1 Создается экземпляр элемента управления |
242 | 240 |
243 =item 1 Выполняется блок конструктора в контексте элемента управления, параметр C<this> имеет значение | 241 =item 1 Выполняется блок конструктора C<CTOR> в контексте элемента управления, параметр C<this> имеет значение |
244 нового экземпляра элемента управления | 242 нового экземпляра элемента управления |
245 | 243 |
246 =back | 244 =back |
247 | 245 |
248 =head1 MEMBERS | 246 =head1 MEMBERS |
249 | 247 |
250 =over | 248 =over |
251 | 249 |
252 =item C<CTOR($template, %options)> | 250 =item C<CTOR($template, $contextOpts, $loader[, $vars])> |
253 | 251 |
254 Создает экземпляр документа с указанным шаблоном и параметрами, параметры | 252 Создает экземпляр документа с указанным шаблоном и параметрами. |
255 | 253 |
256 =back | 254 =over |
255 | |
256 =item C<$template> | |
257 | |
258 C<Template::Document> шаблон документа. | |
259 | |
260 =item C<$contextOpts> | |
261 | |
262 C<HASH> Параметры контекста C<Template::Context> для документа. Эти параметры будут сохранены | |
263 в свойстве C<opts>, а также на их основе будет создан контекст текщего документа. Как правило | |
264 эти параметы задаются загрузчиком документа C<IMPL::Web::View::TTLoader>, таким образом, что | |
265 C<Template::Stash> создаваемого контекста наследует переменные из контекста загрузчика. | |
266 | |
267 =item C<$loader> | |
268 | |
269 C<IMPL::Web::View::TTLoader> загрузчик, который будет использоваться для загрузки элементов управления, | |
270 а также для получения обертки, заданной в свойстве документа C<layout>. | |
271 | |
272 =item C<$vars> | |
273 | |
274 C<HASH> Необязательный параметр. переменные которые будут переданы в блок конструктора C<INIT>. | |
275 Как правило они используются для передачи данных для построения документа | |
276 | |
277 =back | |
278 | |
279 =back | |
280 | |
281 =over | |
282 | |
283 =item C<templateVars($name[,$newValue])> | |
284 | |
285 Получает или задает переменную для шаблона документа. Имя переменнной может быть составным, | |
286 например C<'my.var.name'>, см. C<Template::Stash::set()>. | |
287 | |
288 =item C<require($controlName)> | |
289 | |
290 Загружает фабрику элемента управления, если она уже была загружена, возвращает на нее ссылку. | |
291 При загрузки фабрики для нее создается собственный контекст на основе параметров из свойства | |
292 C<opts> и ее пространство имен наследуется от пространства имен документа из свойства C<stash>. | |
293 | |
294 =item C<Render($vars)> | |
295 | |
296 Выполняет блок C<renderBlock> документа для получения конечного представления, C<$vars> | |
297 содержит переменные для блока. | |
298 | |
299 =item C<RenderContent($vars)> | |
300 | |
301 Выполняет шаблон документа для получения представления содержимого, в отличии от | |
302 метода C<Render> не использует обертку указанную в свойстве C<layout>, если обертка | |
303 не указана, то эти методы идентичны. | |
304 | |
305 =item C<[get,set]layout> | |
306 | |
307 Обертка, которая будет использована для построения представления документа. В обертке | |
308 будет доступна специальная переменная C<content>, при обращении к которой будет B<выполнен> | |
309 метод C<RenderContent()> и возвращен результат его работы. Для получения шаблона обертки | |
310 используется загрузчик из свойства C<loader>. | |
311 | |
312 =item C<[get]opts> | |
313 | |
314 Параметры контекста, используются для создания контекстов фабрик элементов управления. | |
315 | |
316 =item C<[get]loader> | |
317 | |
318 Загрузчик, используется для загрузки шаблонов фабрик элементов управления и обертки. | |
319 | |
320 =item C<[get]controls> | |
321 | |
322 C<HASH> Коллекция загруженных фабрик элементов управления, ключем является | |
323 квалифицированное имя элемента управления. | |
324 | |
325 =item C<[get]stash> | |
326 | |
327 C<Template::Stash> Пространство имен документа, оно используется как родительское | |
328 для пространств имен загружаемых фабрик элементов управления. | |
329 | |
330 =back | |
331 | |
332 =head1 TEMPLATES | |
333 | |
334 =begin text | |
335 | |
336 [%META layout='default'%] | |
337 [% BLOCK CTOR; | |
338 section('top','TOP'); | |
339 section('bottom','BOTTOM'); | |
340 section('client','CLIENT'); | |
341 END %] | |
342 [% BLOCK TOP; | |
343 TMenu = require('my/org/Menu'); | |
344 append(TMenu.new()); | |
345 END %] | |
346 | |
347 =end | |
257 | 348 |
258 =cut | 349 =cut |