SSI loop — Циклы в SSI

в 2:09, , рубрики: Apache, SSI, Веб-разработка, метки: ,

Несмотря на то, что технология SSI (Server Side Includes) не популярна, особенно с приходом CMS. Тем не менее она достаточна удобна для создания небольших сайтов без сложной структуры. Даже тем, кто практически не обладает навыками программирования, она позволяет собрать сайт на основе шаблонов. Об этом уже написано (а чаще скопипащено) немало статей. Помимо включений, SSI обладает условными операторами, а до мало-мальски языка программирования ей не хватает математики, циклов и массивов. С одной из этих проблем, циклами, я и решил разобраться. Вот что у меня получилось.

Саму идею можно описать 1 словом — рекурсия. Дабы не пустозвонить, я просто приведу листинги с небольшим описанием, те кто знаком с SSI разберутся без труда, а остальным следует сначала изучить основы SSI.

Итак для организации цикла понадобится создать 2 файла: вызывающий и тело цикла:
test-lloop.shtml

<!--#set var='i' value='1'-->
<!--#set var='k' value='1'-->
<!--#set var='j' value='111'-->
<!--#include virtual='ssi-loop.shtml' -->

где переменные:

  • i — начальное значение
  • j — шаг
  • k — конечное значени

test-loop.shtml

 <!--#if expr="$i <= $j"-->
всё что вы хотите делать в цикле
<!--#set var="i" value="${i}${k}" -->
<!--#include virtual='ssi-loop.html' -->
<!--#endif -->

В тело вы помешаете любые необходимые вам действия.

Практически я ещё не использовал. Так как массивов нет, то можно что-нибудь замутить с переменными отличающимися на «шаг» и обработкой параметров адресной строки
<!--#include virtual="$QUERY_STRING"-->.

Автор: wakh


* - обязательные к заполнению поля


https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js