Programmer's Reference Guide
| Zend_View |
Einführung
Zend_View ist eine Klasse für die Verarbeitung des "View" Teils des Model-View-Controller
Entwurfsmusters. Er existiert, um das View Skript von den Model und Controller Skripten
zu trennen. Es stellt ein System an Helfern, Ausgabefiltern und Variablenmaskierung bereit.
Zend_View ist unabhängig von einem Template System. Du kannst PHP als Template Sprache
verwenden oder Instanzen anderer Template Systeme erstellen und diese in deinem View Skript
verarbeiten.
Im Wesentlichen verläuft die Verwendung von Zend_View in zwei Hauptschritten:
1. Dein Controller Skript erstellt eine Instanz von Zend_View und übergibt Variablen an
diese Instanz.
2. Der Controller teilt Zend_View mit, ein bestimmtes View Skript zu verarbeiten. Dabei
wird die Kontrolle an das View Skript übergeben, welches die Ausgabe erstellt.
Controller Skript
In einem einfachen Beispiel hat dein Controller Skript eine Liste von Buchdaten, die von einem View Skript verarbeitet werden sollen. Dieses Controller Skript kann ungefähr so aussehen:
<?php
// verwende ein Modell, um die Daten der Bücher und Autoren zu erhalten
$data = array(
array(
'author' => 'Hernando de Soto',
'title' => 'The Mystery of Capitalism'
),
array(
'author' => 'Henry Hazlitt',
'title' => 'Economics in One Lesson'
),
array(
'author' => 'Milton Friedman',
'title' => 'Free to Choose'
)
);
// nun übergebe die Buchdaten an die Zend_View Instanz
Zend_Loader::loadClass('Zend_View');
$view = new Zend_View();
$view->books = $data;
// und verarbeite ein View Skript mit Namen "booklist.php"
echo $view->render('booklist.php');
View Skript
Nun benötigen wir das zugehörige View Skript "booklist.php". Dies ist ein PHP Skript
wie jedes andere mit einer Ausnahme: es wird innerhalb der Zend_View Instanz ausgeführt,
was bedeutet, dass Referenzen auf $this auf die Eigenschaften und Methoden der
Zend_View Instanz weisen. (Variablen, die vom Controller an die Instanz übergeben
wurden, sind öffentliche (public) Eigenschaften der Zend_View Instanz.) Dadurch kann
ein sehr einfaches View Skript wie folgt aussehen:
<?php if ($this->books): ?>
<!-- Eine Tabelle mit einigen Büchern. -->
<table>
<tr>
<th>Autor</th>
<th>Titel</th>
</tr>
<?php foreach ($this->books as $key => $val): ?>
<tr>
<td><?php echo $this->escape($val['author']) ?></td>
<td><?php echo $this->escape($val['title']) ?></td>
</tr>
<?php endforeach; ?>
</table>
<?php else: ?>
<p>Es gibt keine Bücher zum Anzeigen.</p>
<?php endif;
Beachte, wie wir die "escape()" Methode verwenden, um die Variablen für die Ausgabe zu maskieren.
Optionen
Zend_View hat einige Optionen die gesetzt werden können um
das Verhalten deiner View-Skripte zu konfigurieren.
-
basePath: zeigt den Basispfad von dem der Skript-, Helfer- und Filterpfad gesetzt wird. Es nimmt folgende Verzeichnisstruktur an:base/path/ helpers/ filters/ scripts/Das kann über
setBasePath(),addBasePath(), oder diebasePathOption dem Konstruktor gesetzt werden. encoding: zeigt das Verschlüsseln der Zeichen für die Verwendung mithtmlentities(),htmlspecialchars(), und anderen Operationen. Standardwert ist ISO-8859-1 (latin1). Kann übersetEncoding(), oder dieencodingOption im Konstruktor, gesetzt werden.escape: zeigt einen Rückruf welche durchescape()benutzt wird. Kann übersetEscape(), oder dieescapeOption im Konstruktor, gesetzt werden.filter: zeigt einen Filter welcher nach dem Rendern des View Skripts verwendet wird. Kann übersetFilter(),addFilter(), oder diefilterOption im Konstruktor, gesetzt werden.strictVars:zwingtZend_ViewNotizen und Warnungen auszugeben wenn auf nicht initialisierte View Variablen zugegriffen wird. Das kann durch den Aufruf vonstrictVars(true), oder der übergabe derstrictVarsOption im Konstruktor, gesetzt werden.
Zugriff auf Dienstprogramme
Typischerweise ist es nur notwendig assign(), render(), oder eine der
Methoden für das Setzen/Hinzufügen von Filtern, Helfern und Skript-Pfade aufzurufen. Trotzdem, wenn
Zend_View selbst erweitert werden soll, oder auf einige der Internas zugegriffen werden
soll, existieren hierfür einige Zugriffsmöglichkeiten:
-
getVars()gibt alle zugeordneten Variablen zurück. -
clearVars()löscht alle zugeordneten Variablen; Nützlich wenn ein View-Objekt wiederverwendet werden, aber auch kontrolliert werden soll welche Variablen vorhanden sind. -
getScriptPath($script)empfängt den aufgelösten Pfad zu einem gegebenen View Skript. -
getScriptPaths()empfängt alle registrierten Skript-Pfade. -
getHelperPath($helper)empfängt den aufgelösten Pfad zur angegebenen Helferklasse. -
getHelperPaths()empfängt alle registrierten Helferpfade. -
getFilterPath($filter)empfängt den aufgelösten Pfad zur angegebenen Filterklasse. -
getFilterPaths()empfängt alle registrierten Filterpfade.
| Zend_View |
