Chapitre 35. Zend_View

Table des matières

35.1. Introduction
35.1.1. Script du Contrôleur
35.1.2. Script de vue
35.2. Scripts de contrôleur
35.2.1. Assigner des variables
35.2.2. Effectuer le rendu d'un script de vue
35.2.3. Chemin des scripts de vue
35.3. Scripts de vue
35.3.1. Echapper la sortie
35.3.2. Utiliser des systèmes de gabarit (template) alternatifs
35.4. Aides pour la vue
35.4.1. Aides initiales
35.4.2. Chemin des aides
35.4.3. Ecrire des aides personnalisées

35.1. Introduction

Zend_View est une classe qui permet de travailler avec la partie "vue" du design pattern Modèle Vue Contrôleur. Elle existe pour aider à garder la vue séparée du modèle et des scripts du contrôleur. Elle fournie un système d'aide, de filtres d'affichage, et d'échappement de variables.

Zend_View est un système de template agnostique; vous pouvez utiliser PHP comme langage de template, ou créer des instances d'autres systèmes de templates, et les manipuler à travers les scripts de vue.

L'utilisation de Zend_View se déroule en étape principales : 1. Votre script de contrôleur crée une instance de Zend_View et assigne des variables à cette instance. 2. Le contrôleur dit à Zend_View de rendre une vue particulière, et de ce fait va donner le contrôle au script de vue, qui va générer l'affichage.

35.1.1. Script du Contrôleur

Comme exemple simple, imaginons que vous contrôleur aie une liste de données sur des livres qu'il veut rendre en passant par une vue. Le contrôleur pourrait alors ressembler à ceci :

<?php
// utilise un modèle pour obtenir les données sur les livres : auteurs et titres
$data = array(
    array(
        'auteur' => 'Hernando de Soto',
        'titre' => 'Le mystère du capitalisme'
    ),
    array(
        'auteur' => 'Henry Hazlitt',
        'titre' => 'Les sciences économique en un cours'
    ),
    array(
        'auteur' => 'Milton Friedman',
        'titre' => 'Libre de choisir'
    )
);

// assigniation des données du livre à une instance Zend_View
Zend_Loader::loadClass('Zend_View');
$view = new Zend_View();
$view->books = $data;

// et appel du script de rendu d'affichage appelé &quot;booklist.php&quot;
echo $view->render('booklist.php');
?>
        

35.1.2. Script de vue

Maintenant, nous avons besoin d'associer le script de vue, "booklist.php". C'est un script PHP comme les autres, à une exception près : il s'exécute dans la portée de l'instance Zend_View, ce qui veut dire que les référence à $this pointent vers les attributs et les méthodes de Zend_View. (Les variables assignées à l'instance par le contrôleur sont des propriétés publiques de l'instance Zend_View). Ainsi un script de vue de base pourrait ressembler à ceci:

<?php if ($this->books): ?>

    <!-- La table des livres -->
    <table>
        <tr>
            <th>Auteur</th>
            <th>Titre</th>
        </tr>

        <?php foreach ($this->books as $key => $val): ?>
        <tr>
            <td><?php echo $this->escape($val['auteur']) ?></td>
            <td><?php echo $this->escape($val['titre']) ?></td>
        </tr>
        <?php endforeach; ?>

    </table>

<?php else: ?>

    <p>Aucun livre à afficher</p>

<?php endif; ?>
        

Notez l'utilisation de la méthode escape pour échapper les variables à afficher.