Zend_View-Introduction.xml 12 KB

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