Kapitel 35. Zend_View

Inhaltsverzeichnis

35.1. Einführung
35.1.1. Controller Skript
35.1.2. View Skript
35.1.3. Options
35.1.4. Utility Accessors
35.2. Controller Skripte
35.2.1. Variablen übergeben
35.2.2. Verarbeitung eines View Skripts
35.2.3. Pfade für View Skripte
35.3. View Scripte
35.3.1. Ausgaben maskieren
35.3.2. Verwendung alternativer Templatesysteme
35.4. View Helfer
35.4.1. Vorhandene Helfer
35.4.2. Helfer Pfade
35.4.3. Eigene Helfer schreiben

35.1. 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.

35.1.1. 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');
?>
        

35.1.2. 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.

35.1.3. Options

Zend_View has several options that may be set to configure the behaviour of your view scripts.

  • basePath: indicate a base path from which to set the script, helper, and filter path. It assumes a directory structure of:

    base/path/
        helpers/
        filters/
        scripts/
    ]

    This may be set via setBasePath(), addBasePath(), or the basePath option to the constructor.

  • encoding: indicate the character encoding to use with htmlentities(), htmlspecialchars(), and other operations. Defaults to ISO-8859-1 (latin1). May be set via setEncoding() or the encoding option to the constructor.

  • escape: indicate a callback to be used by escape(). May be set via setEscape() or the escape option to the constructor.

  • filter: indicate a filter to use after rendering a view script. May be set via setFilter(), addFilter(), or the filter option to the constructor.

  • strictVars: force Zend_View to emit notices and warnings when uninitialized view variables are accessed. This may be set by calling strictVars(true) or passing the strictVars option to the constructor.

35.1.4. Utility Accessors

Typically, you'll only ever need to call on assign(), render(), or one of the methods for setting/adding filter, helper, and script paths. However, if you wish to extend Zend_View yourself, or need access to some of its internals, a number of accessors exist:

  • getVars() will return all assigned variables.

  • clearVars() will clear all assigned variables; useful when you wish to re-use a view object, but want to control what variables are available..

  • getScriptPath($script) will retrieve the resolved path to a given view script.

  • getScriptPaths() will retrieve all registered script paths.

  • getHelperPath($helper) will retrieve the resolved path to the named helper class.

  • getHelperPaths() will retrieve all registered helper paths.

  • getFilterPath($filter) will retrieve the resolved path to the named filter class.

  • getFilterPaths() will retrieve all registered filter paths.