fenom/docs/ru/tags/include.md

59 lines
2.8 KiB
Markdown
Raw Permalink Normal View History

2014-08-06 22:42:42 +04:00
Тег {include}
2014-08-01 12:12:19 +04:00
=============
Тэги `{include}` используются для включения других шаблонов в текущий. Любые переменные, доступные в текущем шаблоне, доступны и во включаемом.
2014-08-01 12:12:19 +04:00
```smarty
{include "about.tpl"}
```
Вы также можете передать переменные в подключаемый шаблон в виде атрибутов.
Любая переменная, переданная в подключаемый шаблон, доступны только в области видимости подключаемого файла.
Переданные переменные имеют преимущество перед существующими переменными с аналогичными именами.
2014-08-01 12:12:19 +04:00
```smarty
{include "pagination.tpl" count=$total_pages current=$.get.page}
2014-08-01 12:12:19 +04:00
```
Все значения присвоенных переменных восстанавливаются после того, как подключаемый шаблон отработал.
Это значит, что вы можете использовать все переменные из подключающего шаблона в подключаемом, но изменения переменных внутри подключаемого шаблона не будут видны внутри подключающего шаблона после команды {include}.
2014-08-01 12:12:19 +04:00
2014-10-31 00:24:56 +03:00
Если требуется сохранить результат отрисовки шаблона в переменную то используйте `$.fetch($templates, $values)`:
```smarty
{set $data = $.fetch('user.tpl', ["name" => $data.name, "email" => $data.email])}
```
2014-08-01 12:12:19 +04:00
### {insert}
2016-03-28 11:13:26 +03:00
В отличии от `{include}` тег `{insert}` не вызывает дочерний шаблон во время отрисовки, а вставляет код дочернего шаблона в родительский на момент компиляции.
Это позволяет сэкономить ресурсы на проверке и чтении шаблона. Однако такой формат подключения шаблона имеет ограничения.
Имя шаблона должно быть задано явно, без использования переменных и выражений:
2014-08-01 12:12:19 +04:00
```smarty
{insert 'pagination.tpl'} {* отработает *}
{insert $pagination} {* вызовет ошибку *}
```
2014-08-01 12:12:19 +04:00
Рассмотрим тега `{insert}` на примере. Допустим шаблон `main.tpl` имеет следующий код:
2014-08-01 12:12:19 +04:00
```smarty
a: {$a}
{insert 'b.tpl'}
c: {$c}
```
`b.tpl`:
2014-08-01 12:12:19 +04:00
```
b: {$b}
```
Компилятор увидит шаблон `main.tpl` таким:
2014-08-01 12:12:19 +04:00
```smarty
a: {$a}
b: {$b}
c: {$c}
```