1 <sect1 id="zend.view.scripts">
3 <title>View Scripts</title>
6 Eenmaal je controller de variabelen heeft toegewezen en render()
7 heeft opgeroepen zal Zend_View het gevraagde view script oproepen
8 en het binnenin de Zend_View instantie uitvoeren. Daarom wijzen
9 referenties naar $this in je view scripts eigenlijk naar de
10 Zend_View instantie zelf.
14 Variabelen die aan het view script werden toegewezen door de
15 controller worden beschouwd als instantie-eigenschappen. Bijvoorbeeld,
16 indien de controller een variabele 'iets' zou toewijzen, zou je
17 ernaar verwijzen in je view script als $this->iets. (Dit laat je toe
18 de variabelen die werden toegewezen te scheiden van de variabelen die
19 intern zijn aan het script zelf.)
23 Bij wijze van geheugenverfrisser vindt je hieronder het view script van
24 de Zend_View inleiding:
27 <programlisting role="php"><![CDATA[<?php if ($this->books): ?>
29 <!-- Een tabel van enige boeken. -->
36 <?php foreach ($this->books as $key => $val): ?>
38 <td><?php echo $this->escape($val['author']) ?></td>
39 <td><?php echo $this->escape($val['title']) ?></td>
47 <p>Er zijn geen boeken af te beelden.</p>
52 <sect2 id="zend.view.scripts.escaping">
54 <title>Escaping Output</title>
57 Eén van de meest belangrijke taken die in een view script
58 moeten worden uitgevoerd is die welke verzekert dat output
59 op een korrekte wijze wordt ge-escaped; dit helpt, onder andere,
60 cross-site scripting aanvallen te voorkomen. Behalve als je een
61 functie, methode of helper gebruilt die zelf het escapen voor
62 rekening neemt, zou je altijd variabelen moeten escapen als je
67 Zend_View komt met een methode escape() die veel van het escape
68 werk voor je uitvoert.
71 <programlisting role="php"><![CDATA[<?php
72 // slecht gebruik van het view-script:
75 // goed gebruik van het view-script:
76 echo $this->escape($this->variable);
81 Standaard gebruikt de escape() methode de PHP functie htmlspecialchars()
82 om data te escapen. Afhangende van jouw environment zou het kunnen dat je
83 zou willen dat het escapen op een andere manier wordt uitgevoerd. Gebruik
84 de setEscape() methode op controller niveau om Zend_View te laten weten
85 welke escape callback te gebruiken.
88 <programlisting role="php"><![CDATA[<?php
89 // Maak een Zend_View instantie
90 $view = new Zend_View();
92 // vertel het htmlentities te gebruiken als escape callback
93 $view->setEscape('htmlentities');
95 // of vertel het een statische klassemethode te gebruiken als callback
96 $view->setEscape(array('EenClass', 'methodeNaam'));
98 // of zelfs een instantiemethode
99 $obj = new EenClass();
100 $view->setEscape(array($obj, 'methodeNaam'));
102 // en geef dan je view weer
103 echo $view->render(...);
108 De callback functie of methode zou de waarde die ge-escaped moet
109 worden als eerste parameter moeten nemen en alle andere parameters
110 moeten optioneel zijn.
115 <sect2 id="zend.view.scripts.templates">
117 <title>Template Systemen</title>
120 Alhoewel PHP zelf een machtig template systeem is vinden
121 vele developpeurs dat het een tè machtig of complex systeem
122 is voor template designers. Daarom kan het view script
123 gebruikt worden om een ander template objekt te instantiëren
124 en te manipuleren, zoals een PHPLIB-stijl template. Het
125 view script voor dit soort aktiviteir zou er als volgt
129 <programlisting role="php"><![CDATA[<?php
130 include_once 'template.inc';
131 $tpl = new Template();
135 "boeklijst" => "boeklijst.tpl",
136 "elkboek" => "elkboek.tpl",
139 foreach ($this->boeken as $key => $val) {
140 $tpl->set_var('auteur', $this->escape($val['author']);
141 $tpl->set_var('titel', $this->escape($val['title']);
142 $tpl->parse("boeken", "elkboek", true);
145 $tpl->pparse("output", "boeklijst");
147 $tpl->setFile("geenboeken", "geenboeken.tpl")
148 $tpl->pparse("output", "geenboeken");
154 Dit zouden de template bestanden zijn:
157 <programlisting role="html"><![CDATA[
158 <!-- boeklijst.tpl -->
173 <!-- geenboeken.tpl -->
174 <p>Er zijn geen boeken af te beelden.</p>