Zend_View-Introduction.xml 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17406 -->
  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 <acronym>PHP</acronym> 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
  61. <acronym>PHP</acronym> Skript 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 <methodname>setBasePath()</methodname>,
  112. <methodname>addBasePath()</methodname>, 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. <methodname>htmlentities()</methodname>,
  119. <methodname>htmlspecialchars()</methodname>, und anderen Operationen. Standardwert
  120. ist ISO-8859-1 (latin1). Kann über
  121. <methodname>setEncoding()</methodname>, oder die <code>encoding</code> Option im
  122. Konstruktor, gesetzt werden.
  123. </para></listitem>
  124. <listitem><para>
  125. <code>escape</code>: zeigt einen Rückruf welche durch
  126. <methodname>escape()</methodname> benutzt wird. Kann über
  127. <methodname>setEscape()</methodname>, oder die <code>escape</code> Option im
  128. Konstruktor, gesetzt werden.
  129. </para></listitem>
  130. <listitem><para>
  131. <code>filter</code>: zeigt einen Filter welcher nach dem Rendern des View Skripts
  132. verwendet wird. Kann über <methodname>setFilter()</methodname>,
  133. <methodname>addFilter()</methodname>, oder die <code>filter</code> Option im
  134. Konstruktor, gesetzt werden.
  135. </para></listitem>
  136. <listitem><para>
  137. <code>strictVars:</code> zwingt <classname>Zend_View</classname> Notizen und
  138. Warnungen auszugeben wenn auf nicht initialisierte View Variablen zugegriffen wird.
  139. Das kann durch den Aufruf von <methodname>strictVars(true)</methodname>, oder der
  140. Übergabe der <code>strictVars</code> Option im Konstruktor, gesetzt werden.
  141. </para></listitem>
  142. </itemizedlist>
  143. </sect2>
  144. <sect2 id="zend.view.introduction.shortTags">
  145. <title>View Skripte mit Short Tags</title>
  146. <para>
  147. In unseren Beispielen und der Dokumentation verwenden wir <acronym>PHP</acronym> Short
  148. Tags: <code>&lt;?</code> und <code>&lt;?=</code>. Zusätzlich verwenden wir
  149. typischerweise die <ulink
  150. url="http://us.php.net/manual/en/control-structures.alternative-syntax.php">
  151. alternative Syntax für Kontrollstrukturen</ulink>. Diese sind übliche Abkürzungen die
  152. Verwendet werden wenn View Skripte geschrieben werden, da Sie Konstrukte verständlicher
  153. machen und die Anweisungen auf einer einzelnen Zeile belassen.
  154. </para>
  155. <para>
  156. Aber viele Entwickler bevorzugen die Verwendung von Vollen Tags wegen Prüfungen oder
  157. aus Portabilitätsgründen. Zum Beispiel ist <code>short_open_tag</code> in der Datei
  158. php.ini.recommended ausgeschaltet, und wenn man <acronym>XML</acronym> in View Skripten
  159. verwendet werden Short Open Tags dazu führen das die Prüfung des Templates fehlschlägt.
  160. </para>
  161. <para>
  162. Zusätzlich, wenn Short Tags verwendet werden und die Einstellung deaktiviert ist, wird
  163. das View Skript entweder Fehler verursachen oder einfach Code an den Benutzer ausgeben.
  164. </para>
  165. <para>
  166. Für den letzteren Fall, wenn man Short Tags verwenden will, diese aber deaktiviert
  167. sind, gibt es zwei Optionen:
  168. </para>
  169. <itemizedlist>
  170. <listitem>
  171. <para>
  172. Die Short Tags in der <code>.htaccess</code> Datei einschalten:
  173. </para>
  174. <programlisting language="apache"><![CDATA[
  175. php_value "short_open_tag" "on"
  176. ]]></programlisting>
  177. <para>
  178. Das ist nur dann möglich wenn es erlaubt ist <code>.htaccess</code> Dateien zu
  179. erstellen und anzupassen. Diese Direktive kann auch in der
  180. <code>httpd.conf</code> Datei hinzugefügt werden.
  181. </para>
  182. </listitem>
  183. <listitem>
  184. <para>
  185. Einen optionalen Stream Wrapper einschalten um Short Tags zu Long Tags on the
  186. fly zu konvertieren:
  187. </para>
  188. <programlisting language="php"><![CDATA[
  189. $view->setUseStreamWrapper(true);
  190. ]]></programlisting>
  191. <para>
  192. Das registriert <classname>Zend_View_Stream</classname> als Steam Wrapper für
  193. View Skripte, und stellt sicher das der Code weiterhin funktioniert wie wenn
  194. Short Tags eingeschaltet wären.
  195. </para>
  196. </listitem>
  197. </itemizedlist>
  198. <note>
  199. <title>View Stream Wrapper verringert die Geschwindigkeit</title>
  200. <para>
  201. Die Verwendung des Stream Wrapper <emphasis>wird</emphasis> die Geschwindigkeit der
  202. Anwendung verringern, auch wenn es nicht möglich ist Benchmarks durchzuführen um
  203. den Grad der Verlangsamung festzustellen. Wir empfehlen das entweder Short Tags
  204. aktiviert werden, die Skripte volle Tags verwenden, oder eine gute Strategie für
  205. das Cachen von partiellen, und/oder volle Seiteninhalten vorhanden ist.
  206. </para>
  207. </note>
  208. </sect2>
  209. <sect2 id="zend.view.introduction.accessors">
  210. <title>Zugriff auf Dienstprogramme</title>
  211. <para>
  212. Typischerweise ist es nur notwendig <methodname>assign()</methodname>,
  213. <methodname>render()</methodname>, oder eine der Methoden für das Setzen/Hinzufügen von
  214. Filtern, Helfern und Skript-Pfade aufzurufen. Trotzdem, wenn
  215. <classname>Zend_View</classname> selbst erweitert werden soll, oder auf einige der
  216. Internas zugegriffen werden soll, existieren hierfür einige Zugriffsmöglichkeiten:
  217. </para>
  218. <itemizedlist>
  219. <listitem>
  220. <para>
  221. <methodname>getVars()</methodname> gibt alle zugeordneten Variablen zurück.
  222. </para>
  223. </listitem>
  224. <listitem>
  225. <para>
  226. <methodname>clearVars()</methodname> löscht alle zugeordneten Variablen;
  227. Nützlich wenn ein View-Objekt wiederverwendet werden, aber auch kontrolliert
  228. werden soll welche Variablen vorhanden sind.
  229. </para>
  230. </listitem>
  231. <listitem>
  232. <para>
  233. <methodname>getScriptPath($script)</methodname> empfängt den aufgelösten Pfad zu
  234. einem gegebenen View Skript.
  235. </para>
  236. </listitem>
  237. <listitem>
  238. <para>
  239. <methodname>getScriptPaths()</methodname> empfängt alle registrierten
  240. Skript-Pfade.
  241. </para>
  242. </listitem>
  243. <listitem>
  244. <para>
  245. <methodname>getHelperPath($helper)</methodname> empfängt den aufgelösten Pfad
  246. zur angegebenen Helferklasse.
  247. </para>
  248. </listitem>
  249. <listitem>
  250. <para>
  251. <methodname>getHelperPaths()</methodname> empfängt alle registrierten
  252. Helferpfade.
  253. </para>
  254. </listitem>
  255. <listitem>
  256. <para>
  257. <methodname>getFilterPath($filter)</methodname> empfängt den aufgelösten Pfad
  258. zur angegebenen Filterklasse.
  259. </para>
  260. </listitem>
  261. <listitem>
  262. <para>
  263. <methodname>getFilterPaths()</methodname> empfängt alle registrierten
  264. Filterpfade.
  265. </para>
  266. </listitem>
  267. </itemizedlist>
  268. </sect2>
  269. </sect1>
  270. <!--
  271. vim:se ts=4 sw=4 et:
  272. -->