V tomto díle Smarty knihoven je seznámení s řídícími strukturami použitelnými ve Smarty šablonách a s některými funkcemi poskytovanými tímto šablonovacím systémem.
14.3.2005 15:00 | MaReK Olšavský | přečteno 15132×
Smarty šablony poskytují tvůrci www stránek, který je používá zákldní cykly, nebo jejich ekvivalenty poskytované PHP, podmínky, kterými lze například řídit, které části stránky zobrazí. Na tomto místě tutoriálu budou zvedeny je přímo vestavěné funkce Smarty.
Smarty poskytují příkaz podmínky stejným způsobem, jako PHP, tj. včetně stejných operátorů a logických spojek. Relační operátory lze alternovat způsobem, který je známý především programátorům, kteří psali někdy v jazyce Fortran, zejména v jeho starších verzích, než uměl běžnou formu zápisu těchto operátorů. Následující tabulka je v podstatě přejata z originální dokumentace. Podpora těchto alternativních zápisů byla přidána pravděpodobně proto, aby se Smarty mohli pracovat i designéři nemající znalosti z programování.
operátor | PHP ekvivalent | alternativa | příklad | význam |
== | == | eq | $a eq $b | rovno |
!= | != | ne;neq | $a neq $b | různé |
> | > | gt | $a gt $b | větší než |
< | < | lt | $a lt $b | menší než |
>= | >= | ge; gte | $a ge $b | větší, nebo roven než |
<= | <= | le; lte | $a lte $b | menší, než |
! | ! | not | not $a | negace |
% | % | mod | $a mod $b | zbytek celočíselného dělení |
is [not] div by | !($a%$b) [($a%$b)] |
$a is not div by $b | test [ne]dělitelnosti dvou čísel | |
is [not] even | !($a%2) [($a%2)] |
$a is [not] even | Test sudosti [lichosti] čísla | |
is [not] even by | !(($a/$b)%2) [(($a/$b)%2] |
$a is [not] even by $b | Test je-li výsledek dělení sudý [lichý] | |
is [not] odd | ($a%2) [!($a%2)] |
$a is [not] odd | Test lichosti [sudosti] čísla | |
is [not] odd by | (($a/$b)%2) [!(($a%$b)] |
$b is [not] odd by $b | Test lichosti [sudosti] výsledku dělění |
Zápis !($a/$b) má stejný význam jako ($a/$b)==0, zápis ($a/$b) je ekvivalentní zápisu ($a/$b)!=0.
Podmínka if se skládá z několika větví. prvním příkazem je {if podminka}
, může následovat {elseif podminka}
, nebo {else}
dle potřeby existence více větví, konečný příkaz, kterým se uzavírá poslední větev je {/if}
. Podmínky se píší bez závorek, při použití alternativního způsobu zápisu podmínek je nutné mezi podmínkami a proměnnými dělat mezery. výrazy v podmínkách lze spojovat pomocí logických spojek &&, and, || a or.
Složitější, vícenásobné větvení je ve Smarty realizovatelné pouze pomocí sekvencí {if} ... <{elseif} ... >{else}
, konstrukce switch ve Smarty neexistuje, ale dá se použít, protože použitím příkazů {php} a {/php}, pro ukončení bloku PHP, příkazů lze vložit PHP příkazy, ale je to velmi nečisté řešení.
Oblíbený cyklus z PHP, který se používá pro zpracování pole hodnot. Obecně je práce s Polom ve Smarty velice častá, protože výstupy z databáze jsou většinou uloženy do pole. Příkazy a tagy, které se zpracovávají v cyklu foreach jsou uzavřeny mezi pár příkazů {foreach parametry} ... {foreachelse} ... {/foreach}
, pokud vstupní pole neobsahuje žádné hodnoty, je zpracován blok mezi {foreachelse} a {/foreach}.
Parametry cyklu jsou následující:
Použití všech parametrů není nutné, povinými jsou v podstatě jen from a item. Pouze parametr from se nastavuje přímo jako asociované pole, další parametry definují pouze názvy, tj. zapisují se bez znaku $ (string) s výjimkou, která je známa z použití v PHP, kdy v proměnné je uveden název proměné. Parametry from, key a item (respektive vstupní pole přiřazené do from a proměnné jejichž názvy jsou přiřazeny key a name) jsou ekvivalentní použití v PHP cyklu foreach($from as $key=>$item)
.
Data, z pole procházeného v cyklu, jsou v proměnné $itemname.policko
, například $ceny.natural95 zobrazí cenu benzínu Natural 95 z pole benzínových čerpadel. Výstupní data mohou obsahovat další pole (v případě dvou a vícerozměrných polí na vstupu), které potom můžeme zpracovat dalším cyklem.
Další dostupné vlastnosti cyklu foreach jsou dostupné přes proměnnou $smarty.foreach.jmeno.vlastnost, kde jméno je uvedené v nastavitelném parametru name a vlastnosti jsou vyjmenovány níže:
Cyklus {section parametry} ... {/section}
lze použít stejným způsobem, jako foreach, ale má mnohem větší možnosti nastavení, kromě jiného umožnuje nastavení počáteční hodnoty a kroku cyklu. Požadované parametry cyklu jsou loop a name. Podobně jako foreach je použitelná i větev {sectionelse}, která se vykonává v případě, že pole, které je určeno direktivou loop.
Přístup k hodnotám procházeného asociativního pole se realizuje zápisem pole se realizuje pomocí $loop[name].policko
, názorněji je tento přístup ukázán v příkladu. K položkám neasociativního pole se přistupouje pomocí syntaxe $policko[name]
, například $price[pumpa].
Parametry cyklu jsou:
Vlastnosti cyklu, jsou dostupné přes proměnnou $smarty.section.jmeno.vlastnost, kde je jméno nastaveno parametrem name a seznam vlastností je uveden níže:
Tento příkaz již svou strukturou nepatří mezi řídící struktury, ale pomocí něj se dají obejít některá omezení, která s sebou použití Smarty šablon přináší, mezi něž patří například neexistence příkazu ekvivalentního příkazu switch
. Zpracování a zobrazení dat v šabloně je nevhodné, protože je tím narušeno oddělení zpracování dat a prezentace.
Syntaxe je podobná klasickému HTML+PHP souboru, zápis je {php} ... {/php}
, jedná se tedy opět o párový příkaz.
Příklady jsou pro tento díl ve stažitelné příloze. Přístup k databázi je konfigurovatelný v souboru './_superconfig/config.php'. Příloha ke stažení je zde
V tomto díle byly probrány základní řídící struktury pro použití ve Smarty šablonách. V příštím budou další funkce použitelné při Tvorbě stránek, includování dalších šablon (části opakující se ve všech stránkách), cyklus nevázaný na vstupní pole a další.