Программирование на PERL. Работа с шаблонами. Использование HTML-Template с CGI-скриптами
Одной из частых задач стоящих перед Web-программистом является отделение логики получения данных от формата представления данных. Для решения такой задачи часто используют шаблоны html-документов, которые при работе программ заполняются данными. Это позволяет выполнять верстку страниц другому человеку, или изменять внешний вид страниц не изменяя саму программу.
CPAN предоставляет программисту выбор разных средств работы с шаблонами. Среди них: HTML::Template, Text::Template, Template toolkit. Как правило методика работы со всеми этими модулями одинакова. Программист создает объект, указывающий на нужный шаблон, затем формируется набор данных, для заполнения шаблона и выполняется само заполнение шаблона, а результат этого возвращается в виде готовой HTML страницы. Давайте подробнее рассмотрим модуль HTML::Template.
В отличии от других модулей, этот модуль ориентирован на то, что в качестве шаблонов будут использоваться страницы с HTML разметкой. Соответственно, директивы шаблона выглядят подобно HTML тэгам, не мешая HTML редакторам работать с разметкой страницы. С помощью этих директив можно заполнять шаблон разными данными, в зависимости от условных флагов; имитировать циклы, например при заполнении таблиц. При этом все конструкции можно использовать внутри друг друга, создавая шаблоны произвольной сложности.
HTML::Template также позволяет программисту контролировать работу с шаблонами. Например, при использовании данного модуля в сочетании с mod_perl можно использовать кэширование разобранных шаблонов и использовать результаты в разных скриптах. Кроме кэширования программист может задать фильтры, которые будут производить обработку сгенерированного текста. Все параметры шаблонов задаются при создании объекта, описывающего шаблон.
Создание объекта
Для работы с шаблоном необходимо сначала создать объект, который описывает выбранный шаблон. Создание объекта выполняется с помощью вызова оператора new. При этом шаблон может храниться как в файле (ключ filename, наиболее частое применение), в скалярной переменной (ключ scalarref, при этом передается ссылка на объект) и в массиве строк (ключ arrayref, также используется ссылка на список). Кроме перечисленных ключей, могут использоваться и дополнительные, которые обеспечивают более точную настройку поведения объекта.
Вот пример создания объекта из шаблона находящегося в файле template.tmpl, при этом задается, что имена шаблонов будут чувствительны к регистру букв:
my $template = HTML::Template->new(filename => 'template.tmpl', case_sensitive => 1);
Если в системе установлена переменная окружения $HTML_TEMPLATE_ROOT, и при шаблон задан относительным именем файла, то к имени будет добавлено значение $HTML_TEMPLATE_ROOT.
Получение результата
Для получения заполненного шаблона просто вызовите функцию output для нужного объекта. При этом возвращается сгенерированный текст. При этом состояние объекта шаблона не меняется.
Поскольку очень часто результат работы записывается в файл, то для того, чтобы уменьшить загрузку, вы с помощью параметра print_to можете передать функции output дескриптор файла, в который будет происходить выдача результатов. Например, вот так:
$template->output(print_to => *STDOUT);
Вставка переменных
Для вставки данных в шаблон необходимо заполнить его с помощью функции param. Функции param передается хеш данных в виде ключ => значение. Для сложных структур данных, например для вложенных циклов, значением могут быть ссылки на списки и другие хеши. Вот пример простого использования модуля:
use HTML::Template; # открываем файл с шаблоном my $template = HTML::Template->new(filename => 'test.tmpl'); # заполняем шаблон параметрами $template->param(HOME => $ENV, PATH => $ENV); # посылаем заголовок Content-Type print "Content-Type: text/html\n\n"; # выдаем готовый результат print $template->output;
Для использования в шаблоне переменной с именем VARNAME используется конструкция . Значение помещенное в хеш с помощью функции param помещается на место данного тэга. При этом у нас получается документ не полностью соответствующий стандарту HTML. Если вы беспокоитесь о правильности синтаксиса вашего документа, то вместо данного тэга можно использовать следующую форму: . Она работает также, как и предыдущая, но не нарушает правильности HTML документа. Обе эти формы можно использовать внутри других тэгов, например так: ">.
Обработка выводимых переменных может контролироваться параметром тэга с именем ESCAPE. Допустимыми значениями являются HTML и URL, при этом происходит преобразование символов, не разрешенных в данном контексте.
Условные операторы
Другой часто используемой конструкцией является условие. Оно имеет форму
Противоположным по действию тэгу является тег . Он имеет синтаксис
Функция param может быть использована также для получения значения указанного параметра. Для этого просто вызовите функцию с именем нужного параметра.
Оператор цикла
Важным тэгом является тег, обозначающий цикл. Он имеет следущий синтаксис:
Если мы в нашем шаблоне напишем например такую конструкцию
в скрипте заполним этот шаблон данными:
$template->param(EMPLOYEE_INFO => [ < name =>'Иванов', job => 'программист' >, < name =>'Петров', job => 'менеджер' >, ]);
то мы получим следующий вывод (только генерируемая часть шаблона):
Имя: Иванов | Должность: программист |
Имя: Петров | Должность: менеджер |
Важно помнить, что внутри цикла видны только используемые в нем переменные. Для того, чтобы ссылаться на внешние (по отношению к циклу) переменные, вы должны использовать параметр global_vars при создании объекта.
Другие операторы
Модуль также позволяет включать в шаблон другие шаблоны, что помогает использовать повторяющиеся части в разных документах. Для включения файла filename.tmpl используется конструкция . При этом шаблон может включить сам себя и мы получим бесконечную рекурсию. Будьте осторожны! При создании объекта можно указать какая максимальная глубина вложенных файлов может быть достигнута. Это контролируется ключем max_includes.
Заключение
Более подробную информацию о настройках параметров вывода результатов и функциях смотрите справочную страницу HTML::Template.
О других модулях работы с шаблонами мы расскажем в следующих выпусках. Файлы с примерами кода можно скачать в виде ZIP-архива.
Код html в perl
Как вы уже видели в предыдущем разделе, при выводк HTML-кода на браузер из Perl следует предварять символ кавычек обратной косой чертой \" и завершать каждую строчку символом \n, если вы хотите, чтобы ваш код был более читабельным. Все это делает написание скрипта для вывода HTML-кода весьма утомительным занятием.
Вы можете облегчить себе эту работу, используя специальную команду печати, имеющуюся в Perl. Данная команда позволяет распечатать ваш HTML-код, написанный внутри скрипта в обычном для него виде (за исключением некоторых специальных символов). Посмотрите на пример HTML-кода, выводящий на браузер страницу с обычной ссылкой:
#!/usr/bin/perl print "Content-type: text/html\n\n"; print "\n"; print "\n"; print "\n"; print "Click Here\n";
Вследствие необходимости выводить вместо кавычек сочетание \" и все время вставлять в конце строки \n, даже написание этого небольшого фрагмента кода становится утомительным. Гораздо проще сделать это так:
Эта команда print сообщает программе, что следует распечатать страницу HTML-кода, до тех пор пока не встретится метка ENDHTML. Вместо ENDHTML вы можете использовать для обозначения конца HTML-кода любое слово или сочетание букв, которое вам нравится. Главное, чтобы оно совпадало с тем, которое указано после print
#!/usr/bin/perl print "Content-type: text/html\n\n"; print Click Here