Zend_View-Introduction.xml 13 KB

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