Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
21 ошибка прогр... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Пример работы с... 65535
Содержание сайт... 65535
ТЕХНОЛОГИИ ДОСТ... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Создание отчето... 65535
Имитационное мо... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Реклама
Mapei затирка mapei ultracolor.
Сейчас на сайте
Гостей: 12
На сайте нет зарегистрированных пользователей

Пользователей: 13,367
новичок: lanoyac4
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

Расчет обратной матрицы на Delphi + Пояснительная записка
Создание последовательности окон и передвижение окон по экрану на Turbo ...
Двунаправленный динамический список на Delphi + Блок схемы

Шаблонизатор на PHP своими руками
Автор: elrevin

Эта статья предназначена для тех кто не относится скептически к написанию того что уже написано, в общем она для энтузиастов, каким я сам и являюсь.

Начнем с того, что определим что будет уметь наш шаблонизатор:
выделение из шаблона на блоков
обработка блоков
подстановка переменных
Блоки.

Блоки могут быть "циклические" и "не циклические". К первым отнесем блоки приразборе которых шаблонизатор выполнит цикл с определенными параметрами и вставит "внутренности" блока в результирующую страницу несколько раз. Они нам понадобятся массовой для публикации данных (например список заголовков новостей). Ко вторым отнесем условные конструкции (зачастую без них не обойтись).

Имена блоков будем хранить в массиве:

$Blocks=array (array('открывающий тег',
'закрывающий тег',признак цикличного блока));

Чтобы было понятнее разберем пример.

есть таблица новостей:

create table news
(
id int(10) unsigned NOT NULL auto_increment,
title varchar(128),
body text,
ndate date,
primary key (id)
);

нужно создать шаблон для вывода этих новостей и php скрипт обрабатывающий этот шаблон.

Договоримся - теги блоков и переменных будем заключать в HTML комментарии:


содержимое блока


теперь функция выделения блока или переменной:

function ParseTmpl($Block)
{
global $Blocks;
global $Vars;
// Ищем блоки
$Pos=0;
while (($Pos=strpos($Block,'';
if ($EndIndex=strpos($Block,$BlockEnd,$Pos))
{
$EndIndex+=strlen($BlockEnd);

$SubBlock=substr($Block,$Pos,$EndIndex-$Pos);
$Block=substr($Block,0,$Pos).
Block($SubBlock,$BlockId).
substr($Block,$EndIndex);
}
}
else
{
$Pos=strpos($Block,'-->',$Pos);
}
}

//Выделяем переменные

for ($i=0; $i {
$Begin=$Vars[$i];
while ($Pos=strpos($Block,'',$BeginIndex))
{
$Sub=substr($Block,$BeginIndex,$EndIndex-$BeginIndex+3);
$Block=substr($Block,0,$BeginIndex).
Variable($Sub,$i).substr($Block,$EndIndex+3);
}
}
}
return $Block;
}

В качестве аргумента ей передается шаблон или его фрагмент (почему фрагмент? Потому что в нутри блока может быть еще один блок, то есть "внутренность" блока необходимо обработать отдельно). Далее она ищет вхождения строки ',$Offset);
if (($Offset+4)!=$EndInd)
{
$S=substr($Block,$Offset+4,$EndInd-($Offset+4));
$Bl=explode(' ',$S);
$BlockName=$Bl[0];
for ($i=0; $i {
if ($Blocks[$i][0]==$BlockName)
{
return $i;
}
}
}

return -1;
}

Рассмотри работу функции Block($Block, $BlockId):

function Block($Block, $BlockId)
{
global $Blocks;
$Ret='';
// Получаем параметры
$BeginStr=$Blocks[$BlockId][0];
$BeginLength=4+strlen($BeginStr);
$EndOperatorPos=strpos($Block,'-->');
$Operator=substr($Block,$BeginLength,$EndOperatorPos-$BeginLength);
$Args=explode(' ',trim($Operator));

$EndBlockPos=strpos($Block,'');
$SubBlock=substr($Block,$EndOperatorPos+3,$EndBlockPos-$EndOperatorPos-3);
if ($Blocks[$BlockId][2]) // блок не цикличный
{
if ($BeginStr($Args))
{
$Ret.=ParseTmpl($SubBlock);
}
}
else
{
while ($BeginStr($Args))
{
$Ret.=ParseTmpl($SubBlock);
}
}
return $Ret;
}

Ей передаются фрагмент шаблона, содержащий рассматриваемый блок, и индекс блока в массиве $Blocks. Для начала в ней мы разбираем строку открывающего тега, на предмет параметров (это на всякий случай, а вдруг Вам необходимо вывести не все новости а какое-то количество). То есть если блок новостей начинается со строки:



Где 5 - количество выводимых новостей.

Мы должны иметь возможность выделить именно определенное количество новостей. Далее выделяется "внутренность" блока в переменню $SubBlock, для дальнейшего парсирования. Далее в зависимости от результатов проверки на цикличность блока вызываем уже знакомую нам функцию ParseTmpl, либо при выполнении условия, либо в цикле до не выполнения условия. Условием является не нулевой результат выполнения функции одноименной с блоком.

Для каждого циклического блока необходимо создать функцию которая бы возвращала 0 или не 0 в зависимости от того нужно ли повторять разбор блока. Это может быть функция которая будет при каждом вызове выбирать очередную порцию данных из таблицы новостей и возвращать 1 если например количество выбранных новостей не больше количества вереданного ей в качестве одного из элементов массива аргументов блока.
Переменные.

Переменные будем хранить в массиве
$Vars=array('имя переменной');

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

for ($i=0; $i {
$Begin=$Vars[$i];
while ($Pos=strpos($Block,'',$BeginIndex))
{
$Sub=substr($Block,$BeginIndex,$EndIndex-$BeginIndex+3);
$Block=substr($Block,0,$BeginIndex).
Variable($Sub,$i).substr($Block,$EndIndex+3);
}
}
}

И функция Variable:
function Variable($Block, $VarId)
{
global $Vars;
$Ret='';
// Получаем параметры
$BeginStr=$Vars[$VarId];
$BeginLength=4+strlen($BeginStr);
$EndOperatorPos=strpos($Block,'-->');
$Operator=substr($Block,$BeginLength,$EndOperatorPos-$BeginLength);
$Args=explode(' ',trim($Operator));
return $BeginStr($Args);
}

Она похожа на функцию Block, но значительно проще.

Пример шаблона и функции блоков и переменных.

Шаблон вывода наших новостей:











[]




А вот код для работы с блоками и переменными:

$QueryResult_News=0;
$QueryRow_News=0;

function news($Args) // Блок news
{
global $QueryResult_News;
global $QueryRow_News;

$Active=$Args[0];
if ($QueryResult_News==0)
{
$QueryResult_News=mysql_query("select *
from news
by ndate desc limit $Active");
}

if ($QueryRow_News=mysql_fetch_array($QueryResult_News))
{
return 1;
}
else
{
$QueryResult_News=0;
return 0;
}
}


function ndate($Args) // переменная ndate
{
global $QueryRow_News;
if (isset($QueryRow_News['ndate']))
{
return implode('.',array_reverse(explode('-',$QueryRow_News['ndate'],3)));
}
else
{
return '';
}
}

function ntitle($Args) // переменная ntitle
{
global $QueryRow_News;
if (isset($QueryRow_News['title']))
{
return $QueryRow_News['title'];
}
else
{
return '';
}
}

function nbody($Args) // переменная nbody
{
global $QueryRow_News;
if (isset($QueryRow_News['body']))
{
return $QueryRow_News['body'];
}
else
{
return '';
}
}

Массивы $Blocks и $Vars:

$Blocks=array(array('news','news',0))
$Vars=array('ndate','ntitle','nbody');

Ну вот и все простой шаблонизатор готов, все что я хотел сделал, Вам же теперь его модернизировать и усовершенствовать до тех пор пока он не станет удовлетворять всем Вашим ожиданиям :)

Удачи, искренне Ваш elrevin.
Опубликовал Kest November 06 2008 16:46:14 · 0 Комментариев · 8845 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
PHP 5. Практика с...
Длинный заголовок...
ATComponents
Globus VCL Extent...
MicroGPSS Studen ...
Динамические за...
Delphi и технолог...
Создание меню на ...
Еext Editor
Последнее загруж...
PDA версия сайта
Язык программиров...
PHP/MySQL для нач...
3D Октаэдр
Файловый менеджер
Быстрое создание ...
База для Allsubmi...
Игра "Астероиды" ...
Averaging [Исходн...
Pro-Download Sys...

Топ загрузок
Приложение Клие... 100774
Delphi 7 Enterp... 97832
Converter AMR<-... 20268
GPSS World Stud... 17014
Borland C++Buil... 14191
Borland Delphi ... 10290
Turbo Pascal fo... 7373
Калькулятор [Ис... 5984
Visual Studio 2... 5207
Microsoft SQL S... 3661
Случайные статьи
Применение простой...
Постановка задачи
Invalid qualifier
Двоичная композиция
связи
Пример: решение си...
Программирование: ...
Текстовый семибито...
Модуль CGI.pm
Строка доступа к с...
Режим нагрева водо...
Устранение дребезг...
Риски безопасности...
Процедура GETMEM. ...
Кнопка с рисунком
"]" or ".)" expected
Кнопки для перепос...
Просмотр состояния...
Потоки ввода-вывод...
Методы-подставки
Создание примера п...
Онлайн игровые авт...
Самый эффективный ...
Изменение направле...
ЭТАП 3. ВЫЯСНЕНИЕ ...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?