Zend_View-Introduction.xml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15316 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.view.introduction">
  5. <title>Einführung</title>
  6. <para>
  7. <classname>Zend_View</classname> ist eine Klasse für die Verarbeitung des "View" Teils des
  8. Model-View-Controller Entwurfsmusters. Er existiert, um das View Skript von den Model und
  9. Controller Skripten zu trennen. Es stellt ein System an Helfern, Ausgabefiltern und
  10. Variablenmaskierung bereit.
  11. </para>
  12. <para>
  13. <classname>Zend_View</classname> ist unabhängig von einem Template System. Du kannst PHP als Template
  14. Sprache verwenden oder Instanzen anderer Template Systeme erstellen und diese in deinem
  15. View Skript verarbeiten.
  16. </para>
  17. <para>
  18. Im Wesentlichen verläuft die Verwendung von <classname>Zend_View</classname> in zwei Hauptschritten:
  19. 1. Dein Controller Skript erstellt eine Instanz von <classname>Zend_View</classname> und übergibt
  20. Variablen an diese Instanz.
  21. 2. Der Controller teilt <classname>Zend_View</classname> mit, ein bestimmtes View Skript zu
  22. verarbeiten. Dabei wird die Kontrolle an das View Skript übergeben, welches die Ausgabe
  23. erstellt.
  24. </para>
  25. <sect2 id="zend.view.introduction.controller">
  26. <title>Controller Skript</title>
  27. <para>
  28. In einem einfachen Beispiel hat dein Controller Skript eine Liste von Buchdaten, die
  29. von einem View Skript verarbeitet werden sollen. Dieses Controller Skript kann ungefähr
  30. so aussehen:
  31. </para>
  32. <programlisting role="php"><![CDATA[
  33. // verwende ein Modell, um die Daten der Bücher und Autoren zu erhalten
  34. $data = array(
  35. array(
  36. 'author' => 'Hernando de Soto',
  37. 'title' => 'The Mystery of Capitalism'
  38. ),
  39. array(
  40. 'author' => 'Henry Hazlitt',
  41. 'title' => 'Economics in One Lesson'
  42. ),
  43. array(
  44. 'author' => 'Milton Friedman',
  45. 'title' => 'Free to Choose'
  46. )
  47. );
  48. // nun übergebe die Buchdaten an die Zend_View Instanz
  49. Zend_Loader::loadClass('Zend_View');
  50. $view = new Zend_View();
  51. $view->books = $data;
  52. // und verarbeite ein View Skript mit Namen "booklist.php"
  53. echo $view->render('booklist.php');
  54. ]]></programlisting>
  55. </sect2>
  56. <sect2 id="zend.view.introduction.view">
  57. <title>View Skript</title>
  58. <para>
  59. Nun benötigen wir das zugehörige View Skript "booklist.php". Dies ist ein PHP Skript
  60. wie jedes andere mit einer Ausnahme: es wird innerhalb der <classname>Zend_View</classname>
  61. Instanz ausgeführt, was bedeutet, dass Referenzen auf $this auf die Eigenschaften und
  62. Methoden der <classname>Zend_View</classname> Instanz weisen. (Variablen, die vom Controller an
  63. die Instanz übergeben wurden, sind öffentliche (public) Eigenschaften der
  64. <classname>Zend_View</classname> Instanz.) Dadurch kann ein sehr einfaches View Skript wie folgt
  65. aussehen:
  66. </para>
  67. <programlisting role="php"><![CDATA[
  68. <?php if ($this->books): ?>
  69. <!-- Eine Tabelle mit einigen Büchern. -->
  70. <table>
  71. <tr>
  72. <th>Autor</th>
  73. <th>Titel</th>
  74. </tr>
  75. <?php foreach ($this->books as $key => $val): ?>
  76. <tr>
  77. <td><?php echo $this->escape($val['author']) ?></td>
  78. <td><?php echo $this->escape($val['title']) ?></td>
  79. </tr>
  80. <?php endforeach; ?>
  81. </table>
  82. <?php else: ?>
  83. <p>Es gibt keine Bücher zum Anzeigen.</p>
  84. <?php endif;?>
  85. ]]></programlisting>
  86. <para>
  87. Beachte, wie wir die "escape()" Methode verwenden, um die Variablen für die Ausgabe zu
  88. maskieren.
  89. </para>
  90. </sect2>
  91. <sect2 id="zend.view.introduction.options">
  92. <title>Optionen</title>
  93. <para>
  94. <classname>Zend_View</classname> hat einige Optionen die gesetzt werden können um
  95. das Verhalten deiner View-Skripte zu konfigurieren.
  96. </para>
  97. <itemizedlist>
  98. <listitem>
  99. <para>
  100. <code>basePath</code>: zeigt den Basispfad von dem der Skript-, Helfer-
  101. und Filterpfad gesetzt wird. Es nimmt folgende Verzeichnisstruktur an:
  102. </para>
  103. <programlisting role="php"><![CDATA[
  104. base/path/
  105. helpers/
  106. filters/
  107. scripts/
  108. ]]></programlisting>
  109. <para>
  110. Das kann über <code>setBasePath()</code>,
  111. <code>addBasePath()</code>, oder die <code>basePath</code>
  112. Option dem Konstruktor gesetzt werden.
  113. </para>
  114. </listitem>
  115. <listitem><para>
  116. <code>encoding</code>: zeigt das Verschlüsseln der Zeichen für die Verwendung mit
  117. <code>htmlentities()</code>, <code>htmlspecialchars()</code>, und anderen
  118. Operationen. Standardwert ist ISO-8859-1 (latin1). Kann über
  119. <code>setEncoding()</code>, oder die <code>encoding</code> Option im Konstruktor,
  120. gesetzt werden.
  121. </para></listitem>
  122. <listitem><para>
  123. <code>escape</code>: zeigt einen Rückruf welche durch <code>escape()</code> benutzt
  124. wird. Kann über <code>setEscape()</code>, oder die <code>escape</code> Option im
  125. Konstruktor, gesetzt werden.
  126. </para></listitem>
  127. <listitem><para>
  128. <code>filter</code>: zeigt einen Filter welcher nach dem Rendern des View Skripts
  129. verwendet wird. Kann über <code>setFilter()</code>, <code>addFilter()</code>, oder
  130. die <code>filter</code> Option im Konstruktor, gesetzt werden.
  131. </para></listitem>
  132. <listitem><para>
  133. <code>strictVars:</code> zwingt <classname>Zend_View</classname> Notizen und Warnungen
  134. auszugeben wenn auf nicht initialisierte View Variablen zugegriffen wird. Das kann
  135. durch den Aufruf von <code>strictVars(true)</code>, oder der übergabe der
  136. <code>strictVars</code> Option im Konstruktor, gesetzt werden.
  137. </para></listitem>
  138. </itemizedlist>
  139. </sect2>
  140. <sect2 id="zend.view.introduction.shortTags">
  141. <title>View Skripte mit Short Tags</title>
  142. <para>
  143. In unseren Beispielen und der Dokumentation verwenden wir PHP Short Tags:
  144. <code>&lt;?</code> und <code>&lt;?=</code>. Zusätzlich verwenden wir typischerweise die
  145. <ulink url="http://us.php.net/manual/en/control-structures.alternative-syntax.php">
  146. alternative Syntax für Kontrollstrukturen</ulink>. Diese sind übliche Abkürzungen die
  147. Verwendet werden wenn View Skripte geschrieben werden, da Sie Konstrukte verständlicher
  148. machen und die Anweisungen auf einer einzelnen Zeile belassen.
  149. </para>
  150. <para>
  151. Aber viele Entwickler bevorzugen die Verwendung von Vollen Tags wegen Prüfungen oder
  152. aus Portabilitätsgründen. Zum Beispiel ist <code>short_open_tag</code> in der Datei
  153. php.ini.recommended ausgeschaltet, und wenn man XML in View Skripten verwendet werden
  154. Short Open Tags dazu führen das die Prüfung des Templates fehlschlägt.
  155. </para>
  156. <para>
  157. Zusätzlich, wenn Short Tags verwendet werden und die Einstellung deaktiviert ist, wird
  158. das View Skript entweder Fehler verursachen oder einfach Code an den Benutzer ausgeben.
  159. </para>
  160. <para>
  161. Für den letzteren Fall, wenn man Short Tags verwenden will, diese aber deaktiviert
  162. sind, gibt es zwei Optionen:
  163. </para>
  164. <itemizedlist>
  165. <listitem>
  166. <para>
  167. Die Short Tags in der <code>.htaccess</code> Datei einschalten:
  168. </para>
  169. <programlisting role="apache"><![CDATA[
  170. php_value "short_open_tag" "on"
  171. ]]></programlisting>
  172. <para>
  173. Das ist nur dann möglich wenn es erlaubt ist <code>.htaccess</code> Dateien zu
  174. erstellen und anzupassen. Diese Direktive kann auch in der
  175. <code>httpd.conf</code> Datei hinzugefügt werden.
  176. </para>
  177. </listitem>
  178. <listitem>
  179. <para>
  180. Einen optionalen Stream Wrapper einschalten um Short Tags zu Long Tags on the
  181. fly zu konvertieren:
  182. </para>
  183. <programlisting role="php"><![CDATA[
  184. $view->setUseStreamWrapper(true);
  185. ]]></programlisting>
  186. <para>
  187. Das registriert <classname>Zend_View_Stream</classname> als Steam Wrapper für View
  188. Skripte, und stellt sicher das der Code weiterhin funktioniert wie wenn Short
  189. Tags eingeschaltet wären.
  190. </para>
  191. </listitem>
  192. </itemizedlist>
  193. <note>
  194. <title>View Stream Wrapper verringert die Geschwindigkeit</title>
  195. <para>
  196. Die Verwendung des Stream Wrapper <emphasis>wird</emphasis> die Geschwindigkeit der
  197. Anwendung verringern, auch wenn es nicht möglich ist Benchmarks durchzuführen um
  198. den Grad der Verlangsamung festzustellen. Wir empfehlen das entweder Short Tags
  199. aktiviert werden, die Skripte volle Tags verwenden, oder eine gute Strategie für
  200. das Cachen von partiellen, und/oder volle Seiteninhalten vorhanden ist.
  201. </para>
  202. </note>
  203. </sect2>
  204. <sect2 id="zend.view.introduction.accessors">
  205. <title>Zugriff auf Dienstprogramme</title>
  206. <para>
  207. Typischerweise ist es nur notwendig <code>assign()</code>, <code>render()</code>, oder
  208. eine der Methoden für das Setzen/Hinzufügen von Filtern, Helfern und Skript-Pfade
  209. aufzurufen. Trotzdem, wenn <classname>Zend_View</classname> selbst erweitert werden soll, oder
  210. auf einige der Internas zugegriffen werden soll, existieren hierfür einige
  211. Zugriffsmöglichkeiten:
  212. </para>
  213. <itemizedlist>
  214. <listitem>
  215. <para>
  216. <code>getVars()</code> gibt alle zugeordneten Variablen zurück.
  217. </para>
  218. </listitem>
  219. <listitem>
  220. <para>
  221. <code>clearVars()</code> löscht alle zugeordneten Variablen; Nützlich wenn ein
  222. View-Objekt wiederverwendet werden, aber auch kontrolliert werden soll welche
  223. Variablen vorhanden sind.
  224. </para>
  225. </listitem>
  226. <listitem>
  227. <para>
  228. <code>getScriptPath($script)</code> empfängt den aufgelösten Pfad zu einem
  229. gegebenen View Skript.
  230. </para>
  231. </listitem>
  232. <listitem>
  233. <para>
  234. <code>getScriptPaths()</code> empfängt alle registrierten Skript-Pfade.
  235. </para>
  236. </listitem>
  237. <listitem>
  238. <para>
  239. <code>getHelperPath($helper)</code> empfängt den aufgelösten Pfad zur
  240. angegebenen Helferklasse.
  241. </para>
  242. </listitem>
  243. <listitem>
  244. <para>
  245. <code>getHelperPaths()</code> empfängt alle registrierten Helferpfade.
  246. </para>
  247. </listitem>
  248. <listitem>
  249. <para>
  250. <code>getFilterPath($filter)</code> empfängt den aufgelösten Pfad zur
  251. angegebenen Filterklasse.
  252. </para>
  253. </listitem>
  254. <listitem>
  255. <para>
  256. <code>getFilterPaths()</code> empfängt alle registrierten Filterpfade.
  257. </para>
  258. </listitem>
  259. </itemizedlist>
  260. </sect2>
  261. </sect1>
  262. <!--
  263. vim:se ts=4 sw=4 et:
  264. -->