2
0

Zend_View-Introduction.xml 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17406 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.view.introduction">
  5. <title>Introduction</title>
  6. <para>
  7. <classname>Zend_View</classname> est une classe qui permet de travailler avec la
  8. partie "Vue" du motif de conception Modèle-Vue-Contrôleur. Elle existe pour aider à garder
  9. la vue séparée du modèle et des scripts du contrôleur. Elle fournie un système d'aide, de
  10. filtres d'affichage, et d'échappement de variables.
  11. </para>
  12. <para>
  13. <classname>Zend_View</classname> est un système de template agnostique ; vous pouvez
  14. utiliser <acronym>PHP</acronym> comme langage de template, ou créer des instances d'autres systèmes de
  15. templates, et les manipuler à travers les scripts de vue.
  16. </para>
  17. <para>
  18. L'utilisation de <classname>Zend_View</classname> se déroule en deux étapes
  19. principales : 1. Votre script de contrôleur crée une instance de
  20. <classname>Zend_View</classname> et assigne des variables à cette instance. 2. Le contrôleur
  21. dit à <classname>Zend_View</classname> d'effectuer le rendu d'une vue particulière, et de ce
  22. fait va donner le contrôle au script de vue, qui va générer l'affichage.
  23. </para>
  24. <sect2 id="zend.view.introduction.controller">
  25. <title>Script du Contrôleur</title>
  26. <para>
  27. Comme exemple simple, imaginons que votre contrôleur aie une liste de données sur
  28. des livres qu'il veut afficher en passant par une vue. Le contrôleur pourrait alors
  29. ressembler à ceci :
  30. </para>
  31. <programlisting language="php"><![CDATA[
  32. // utilise un modèle pour obtenir les données sur les livres :
  33. // auteurs et titres
  34. $data = array(
  35. array(
  36. 'auteur' => 'Hernando de Soto',
  37. 'titre' => 'Le mystère du capitalisme'
  38. ),
  39. array(
  40. 'auteur' => 'Henry Hazlitt',
  41. 'titre' => 'Les sciences économique en un cours'
  42. ),
  43. array(
  44. 'auteur' => 'Milton Friedman',
  45. 'titre' => 'Libre de choisir'
  46. )
  47. );
  48. // assigniation des données du livre à une instance Zend_View
  49. Zend_Loader::loadClass('Zend_View');
  50. $view = new Zend_View();
  51. $view->books = $data;
  52. // et appel du script de rendu d'affichage appelé "booklist.php"
  53. echo $view->render('booklist.php');
  54. ]]></programlisting>
  55. </sect2>
  56. <sect2 id="zend.view.introduction.view">
  57. <title>Script de vue</title>
  58. <para>
  59. Maintenant, nous avons besoin d'associer le script de vue
  60. "<filename>booklist.php</filename>". C'est un script <acronym>PHP</acronym> comme les autres, à une
  61. exception près : il s'exécute dans la portée de l'instance
  62. <classname>Zend_View</classname>, ce qui veut dire que les référence à
  63. <varname>$this</varname> pointent vers les attributs et les méthodes de
  64. <classname>Zend_View</classname>. (Les variables assignées à l'instance par le
  65. contrôleur sont des propriétés publiques de l'instance
  66. <classname>Zend_View</classname>). Ainsi un script de vue de base pourrait ressembler à
  67. ceci :
  68. </para>
  69. <programlisting language="php"><![CDATA[
  70. <?php if ($this->books): ?>
  71. <!-- La table des livres -->
  72. <table>
  73. <tr>
  74. <th>Auteur</th>
  75. <th>Titre</th>
  76. </tr>
  77. <?php foreach ($this->books as $key => $val): ?>
  78. <tr>
  79. <td><?php echo $this->escape($val['auteur']) ?></td>
  80. <td><?php echo $this->escape($val['titre']) ?></td>
  81. </tr>
  82. <?php endforeach; ?>
  83. </table>
  84. <?php else: ?>
  85. <p>Aucun livre à afficher</p>
  86. <?php endif; ?>
  87. ]]></programlisting>
  88. <para>
  89. Notez l'utilisation de la méthode <code>escape</code> pour échapper les variables
  90. à afficher.
  91. </para>
  92. </sect2>
  93. <sect2 id="zend.view.introduction.options">
  94. <title>Options</title>
  95. <para>
  96. <classname>Zend_View</classname> possède plusieurs options qui peuvent être
  97. réglées pour changer le comportement de vos scripts de vues.
  98. </para>
  99. <itemizedlist>
  100. <listitem>
  101. <para>
  102. <code>basePath</code> : indique le chemin de base où peuvent être trouvés
  103. les dossiers de scripts, d'aides et de filtres. Il considère une structure de
  104. dossiers de ce type :
  105. </para>
  106. <programlisting language="php"><![CDATA[
  107. chemin/vers/
  108. helpers/
  109. filters/
  110. scripts/
  111. ]]></programlisting>
  112. <para>
  113. Ceci peut être paramétré via les méthodes <methodname>setBasePath()</methodname>,
  114. <methodname>addBasePath()</methodname>, ou l'option <code>basePath</code> du
  115. constructeur.
  116. </para>
  117. </listitem>
  118. <listitem>
  119. <para>
  120. <code>encoding</code> : indique l'encodage de caractère à utiliser avec
  121. <methodname>htmlentities()</methodname>, <methodname>htmlspecialchars()</methodname>, et tout autre
  122. opération. La valeur par défaut est ISO-8859-1 (latin1). Il peut être paramétré
  123. avec la méthode <methodname>setEncoding()</methodname> ou l'option <code>encoding</code> du
  124. constructeur.
  125. </para>
  126. </listitem>
  127. <listitem>
  128. <para>
  129. <code>escape</code> : indique le callback que doit utiliser
  130. <methodname>escape()</methodname>. Ceci pet être paramétré avec la méthode
  131. <methodname>setEscape()</methodname> ou l'option <code>escape</code> du constructeur.
  132. </para>
  133. </listitem>
  134. <listitem>
  135. <para>
  136. <code>filter</code> : indique un filtre à utiliser avant d'effectuer le
  137. rendu d'un script de vue. Ceci peut être paramétré avec les méthodes
  138. <methodname>setFilter()</methodname>, <methodname>addFilter()</methodname>, ou l'option
  139. <code>filter</code> du constructeur.
  140. </para>
  141. </listitem>
  142. <listitem>
  143. <para>
  144. <code>strictVars</code> : force <classname>Zend_View</classname> à émettre
  145. des "notices" et des "warnings" quand des variables non initialisées sont lues.
  146. Ceci peut être activé en appelant <methodname>strictVars(true)</methodname> ou en passant
  147. l'option <code>strictVars</code> au constructeur.
  148. </para>
  149. </listitem>
  150. </itemizedlist>
  151. </sect2>
  152. <sect2 id="zend.view.introduction.shortTags">
  153. <title>Balises courtes dans les scripts de vue</title>
  154. <para>
  155. Dans nos exemples et notre documentation, nous utilisons les balises courtes <acronym>PHP</acronym> :
  156. <code>&lt;?</code> and <code>&lt;?=</code>. De plus, nous utilisons parfois <ulink
  157. url="http://us.php.net/manual/en/control-structures.alternative-syntax.php">la syntaxe
  158. alternative des structures de contrôle</ulink>. Ce sont des éléments pratiques à
  159. utiliser lors de la rédaction de vos scripts de vue, car elles rendent les constructions
  160. plus laconiques, et maintiennent les instructions sur des lignes uniques.
  161. </para>
  162. <para>
  163. Ceci étant dit, de nombreux développeurs préfère utiliser la forme complète pour
  164. des questions de validation ou de portabilité. Par exemple, <code>short_open_tag</code>
  165. est désactivé dans le <firstterm>php.ini.recommended</firstterm>, et si vous avez du <acronym>XML</acronym>
  166. dans vos scripts de vue, alors les balises courtes entraîneront un échec de validation
  167. du modèle.
  168. </para>
  169. <para>
  170. De plus, si vous utilisez les balises courtes avec un réglage du paramètre à
  171. "off", alors les scripts de vue vont soit entraîner des erreurs, soit simplement
  172. afficher le code à l'utilisateur.
  173. </para>
  174. <para>
  175. Pour ce dernier cas, quand vous souhaitez utiliser les balises courtes mais
  176. qu'elles sont désactivées, vous avez deux options :
  177. </para>
  178. <itemizedlist>
  179. <listitem>
  180. <para>Activer les dans votre fichier <code>.htaccess</code> :</para>
  181. <programlisting language="apache"><![CDATA[
  182. php_value "short_open_tag" "on"
  183. ]]></programlisting>
  184. <para>
  185. Ceci est seulement possible si vous êtes autorisé à créer et utiliser les
  186. fichiers <code>.htaccess</code>. Cette directive peut aussi être ajoutée à votre
  187. fichier <code>httpd.conf</code>.
  188. </para>
  189. </listitem>
  190. <listitem>
  191. <para>
  192. Activer une enveloppe de flux ("stream wrapper") optionnelle pour
  193. convertir les balises courtes en balises longues à la volée :
  194. </para>
  195. <programlisting language="php"><![CDATA[
  196. $view->setUseStreamWrapper(true);
  197. ]]></programlisting>
  198. <para>
  199. Ceci enregistre <classname>Zend_View_Stream</classname> en tant que
  200. enveloppe de flux pour les scripts de vue, et permet de s'assurer que votre code
  201. continue à fonctionner comme si les balises courtes étaient activées.
  202. </para>
  203. </listitem>
  204. </itemizedlist>
  205. <note>
  206. <title>Les enveloppes de flux de vue dégradent les performances</title>
  207. <para>
  208. L'utilisation d'enveloppe de flux <emphasis>dégradera</emphasis> les
  209. performances de votre application, bien que les tests de performance réels sont
  210. indisponibles pour quantifier le niveau de dégradation. Nous recommandons donc soit
  211. d'activer les balises courtes, soit de convertir vos scripts pour utiliser la forme
  212. longue, ou d'avoir une bonne stratégie de mise en cache partielle ou totale du
  213. contenu de vos pages.
  214. </para>
  215. </note>
  216. </sect2>
  217. <sect2 id="zend.view.introduction.accessors">
  218. <title>Accesseurs utiles</title>
  219. <para>
  220. Typiquement, vous ne devriez seulement avoir besoin d'appeler les méthodes
  221. <methodname>assign()</methodname>, <methodname>render()</methodname>, ou une des méthodes pour le
  222. paramétrage/l'ajout de chemins de filtre, d'aide et de script de vues. Cependant, si
  223. vous souhaitez étendre <classname>Zend_View</classname> vous-même, ou avez besoin
  224. d'accéder à quelques unes de ces méthodes internes, un certain nombre d'accesseurs
  225. existent :
  226. </para>
  227. <itemizedlist>
  228. <listitem>
  229. <para><methodname>getVars()</methodname> retournera toutes les variables assignées.</para>
  230. </listitem>
  231. <listitem>
  232. <para>
  233. <methodname>clearVars()</methodname> effacera toutes les variables assignées ; utile
  234. si vous souhaitez ré-utiliser un objet de vue, ou contrôler les variables qui
  235. sont disponibles.
  236. </para>
  237. </listitem>
  238. <listitem>
  239. <para>
  240. <methodname>getScriptPath($script)</methodname> récupérera le chemin résolu vers un
  241. script donné..
  242. </para>
  243. </listitem>
  244. <listitem>
  245. <para>
  246. <methodname>getScriptPaths()</methodname> récupérera tous les chemins vers les scripts
  247. de vues enregistrés.
  248. </para>
  249. </listitem>
  250. <listitem>
  251. <para>
  252. <methodname>getHelperPath($helper)</methodname> récupérera le chemin résolu vers une
  253. classe d'aide nommée.
  254. </para>
  255. </listitem>
  256. <listitem>
  257. <para>
  258. <methodname>getHelperPaths()</methodname> récupérera tous les chemins vers les aides
  259. enregistrés.
  260. </para>
  261. </listitem>
  262. <listitem>
  263. <para>
  264. <methodname>getFilterPath($filter)</methodname> récupérera le chemin résolu vers une
  265. classe de filtre nommée.
  266. </para>
  267. </listitem>
  268. <listitem>
  269. <para>
  270. <methodname>getFilterPaths()</methodname> récupérera tous les chemins vers les filtres
  271. enregistrés.
  272. </para>
  273. </listitem>
  274. </itemizedlist>
  275. </sect2>
  276. </sect1>