UpMark -  System of Professional Certification
UpMark - Система Сертификации Специалистов. Пройди тест - получи сертификат.   система
система тестирование
UpMark : Шаблоны документов и Perl : Сделать стартовойСделать закладку
 Шаблоны документов и Perl
Всегда, когда нам необходимо написать CGI скрипт на Perl
мы сталкиваемся с тем, что скрипт должен возвращать
пользователю некоторый HTML код.
Как правило, этот код вставляется непосредственно
в код самого скрипта.

Данный подход не совсем удобен в том плане,
что при изменении дизайна сайта, как правило,
приходится изменять текст скрипта. Вы наверно замечали,
что очень часто "скриптовая" часть сервера несколько
отличается от остальной части сайта.
Происходит это именно по той причине, что в самом коде
скрипта довольно сложно изменять HTML фрагменты.
Где-то да просчитаетесь.

Второй, наиболее популярный, вариант - это вынесение
переменных с HTML в отдельный файл.
Это конечно облегчает жизнь, но не дает полной свободы.
Предложенный ниже скрипт состоит всего лишь из 30 строк,
но зато он решает все описанные выше проблемы.



Итак, для начала решим, что все наши HTML данные
будут храниться в файле - шаблоне.
Назовем его templ.tmpl Формат файла будет следующий:


#! Название_фрагмента

# Комментарий

Любой текст

#! Название_второго_фрагмента

Еще текст


Кроме того, в тексте можно использовать такие конструкции:



@Имя@ - подставить значение переменной "Имя"

@#Имя@ - подставить фрагмент с названием "Имя".

Заметьте, что подстановка идет рекурсивно и в подставляемых блоках,
так же можно использовать подстановки.



Теперь напишем функцию, которая читала бы читала
этот файл, преобразовывала его (делала подстановки фрагментов)
и сохраняла фрагменты в хеше. При этом, имена элементов хеша,
будут соответствовать именам фрагментов.





sub read_from_dot {

my ($line, $curname);
2 open (F, $_<0>) || die "Не могу открыть $_<0>";
3 foreach $line () {

4 chomp($line);
5 if (( $line !~ /^#<^!>/ ) &&
( $line ne "#" )){
6 if ($line =~ /^#!s+/){
7 $curname=$`;
}
9 else{
10 $DOT{$curname}.="$line";
}
}
}
14 close(F);

16 foreach (keys %DOT){
17 $DOT{$_} =~ s/@#(.<^@>*)@/$DOT{"$1"}/g;
}
}




2 - Открываем файл. Имя файла должно быть передано как аргумент функции.

3 - Пробегаем по всем строчкам файла.

4 - Избавляемся от символа конца строки.

5 - Если строка начинается с "#" (причем после нее стоит не "!"),
то работаем с ней. Иначе - теряем. Поскольку это комментарий.

6 - Если строка начинается на "#!", значит это название очередного фрагмента.

7 - Запомним имя текущего фрагмента.

9-10 - Если это просто строка, добавляем ее в элемент хеша с
именем равным имени текущего фрагмента.

14 - Закрываем файл.




Процедура рекурсивной подстановки



16 - Пробегаем по всем элементам хеша %DOT.



17 - Заменяем все конструкции вида @#NAME@ на текст фрагмента с именем "NAME".





Вот и все. У нас готов глобальный хеш %DOT, в котором содержатся все наши шаблоны.

Возьмем для примера такой файл-шаблон:



#! MAIN
###########################################
@#TITLE@
Это главная страница

#! STYLE
###########################################


#! TITLE
#
# @STRING@ - имя
###########################################


@#STYLE@
@STRING@




После обработки получим хеш из трех элементов MAIN, STYLE, TITLE.


Ну и наконец напишем функцию, которая будет подставлять
значения переменных.

Чтобы переменные не пересекались с переменными, используемыми в скрипте,
будем хранить их в хеше %DOT_VAL.



sub insert_values {
1 if ($_<0>){
2 $_<0> =~ s/@(.<^@>*)@/$DOT_VAL{$1}/g;
}
else{
5 foreach (keys %DOT){
6 $DOT{$_} =~ s/@(.<^@>*)@/$DOT_VAL{$1}/g;
}
}
}



1 - Если функция вызывается с аргументом, то замена
переменных происходит в этом аргументе.
Иначе замена переменных происходит во всем хеше $DOT.



2 - Подстановка переменных.

5 - Бежим по всем элементам хеша %DOT

6 - Подставляем значения переменных.





Ну и на последок пример использования данного кода.



read_from_dot("templ.tmpl");
$DOT_VAL{STRING}="Welcome to our site!!!";
insert_values();
print $DOT{"MAIN"};

_________________________________________________________________

Philip A. Koryaka


© Upmark.ru


Отзывы:
отзывов пока нет, ваш будет первым!

Оставьте свой отзыв:
Ваше имя:

Ваш отзыв о "Шаблоны документов и Perl":

контрольный код:




Смотрите также:
  • Как работодатели смотрят на сертификаты и оценки в дипломах?
  • Mandrake Linux 9.2. Море удовольствия
  • Шаблоны документов и Perl
  • Сводная таблица переменных HTTP сервера
  • Регулярные выражения

    Вы читали "Шаблоны документов и Perl"
  •   

    © 2004—2012 UpMark ltd
    регистрация  |  тесты  |  библиотека  |  каталог сайтов  |  контакты