Zend_View-Helpers.xml 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15157 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.view.helpers" xmlns:xi="http://www.w3.org/2001/XInclude">
  5. <title>View Helfer</title>
  6. <para>
  7. In deinen View Skripten ist es oft notwendig, bestimmte komplexe Funktionen immer wieder
  8. auszuführen, z.B. Datum formatieren, Formularelemente erstellen oder Links für Aktionen
  9. anzuzeigen. Du kannst Helferklassen verwenden, um diese Aufgaben für dich durchführen zu
  10. lassen.
  11. </para>
  12. <para>
  13. Ein Helfer ist einfach eine Klasse. Nehmen wir an wir wollen einen Helfer der 'fooBar' heißt.
  14. Standardmäßig wird der Klasse 'Zend_View_Helper_' vorangestellt (Es kann ein
  15. eigener Prefix definiert werden wenn ein Pfad für die Helfer definiert wird), und das letzte
  16. Segment des Klassennamens ist der Name des Helfers; Dieses Segment sollte TitelGroßgeschrieben
  17. sein; der volle Klassenname ist dann: <classname>Zend_View_Helper_FooBar</classname>. Diese Klasse
  18. sollte mindestens eine einzelne Methode enthalten, die nach dem Helfer benannt und
  19. camelCased ist: <code>fooBar()</code>.
  20. </para>
  21. <note>
  22. <title>Betrachte den Fall</title>
  23. <para>
  24. Namen von Helfern sind immer camelCased, bzw. beginnen Sie nie mit einem
  25. großgeschriebenen Zeichen. Der Klassenname selbst ist MixedCased, aber die Methode die
  26. aktuell ausgeführt wird ist camelCased.
  27. </para>
  28. </note>
  29. <note>
  30. <title>Standard Helfer Pfad</title>
  31. <para>
  32. Der Standard Helfer Pfad zeigt immer zu den View Helfern des Zend Frameworks,
  33. normalerweise 'Zend/View/Helper/'. Selbst wenn <code>setHelperPath()</code> ausgerufen
  34. wird um den existierenden Pfad zu überschreiben, wird dieser Pfad gesetzt um
  35. sicherzustellen das die Standard Helfer arbeiten.
  36. </para>
  37. </note>
  38. <para>
  39. Um einen Helfer in deinem View Skript zu verwenden, rufe ihn mittels
  40. <code>$this->helperName()</code> auf. Im Hintergrund wird <classname>Zend_View</classname> die Klasse
  41. <classname>Zend_View_Helper_HelperName</classname> laden, eine Objektinstanz der Klasse erstellen und
  42. deren Methode <code>helperName()</code> aufrufen. Die Objektinstanz bleibt innerhalb der
  43. <classname>Zend_View</classname> Instanz bestehen und wird bei allen weiteren Aufrufen von
  44. <code>$this->helperName()</code> wiederverwendet.
  45. </para>
  46. <sect2 id="zend.view.helpers.initial">
  47. <title>Vorhandene Helfer</title>
  48. <para>
  49. <classname>Zend_View</classname> enthält bereits einige vorhandene Helferklassen, die sich alle
  50. auf die Erstellung von Formularelementen beziehen und die notwendige Maskierung der
  51. Ausgaben automatisch vornehmen. Zusätzlich gibt es Helfer zum Erstellen Routen-basierter
  52. URLS and HTML Listen, genauso wie für das Deklarieren von Variablen. Die aktuell
  53. gelieferten Helfer beinhalten:
  54. </para>
  55. <itemizedlist>
  56. <listitem><para>
  57. <code>declareVars()</code>: Primär benutzt mit <code>strictVars()</code>, kann
  58. dieser Helfer verwendet werden um template Variablen zu deklarieren welche
  59. bereits, oder noch nicht, im View Objekt bereits gesetzt sind, sowie auch
  60. Standard Werte. Arrays welche als Argument dieser Methode übergeben werden, werden
  61. verwendet um Standard Werte zu setzen; Andernfalls, wenn die Variable nicht
  62. existiert, wird diese mit einem leeren String gesetzt.
  63. </para></listitem>
  64. <listitem><para>
  65. <code>fieldset($name, $content, $attribs):</code> Erstellt ein XHTML Fieldset.
  66. Wenn <code>$attribs</code> einen 'legend' Schlüssel enthält, wird der Wert für
  67. die Fieldset Beschriftung verwendet. Das Fieldset wird <code>$content</code>
  68. umfassen wie vom Helfer angeboten.
  69. </para></listitem>
  70. <listitem><para>
  71. <code>form($name, $attribs, $content):</code> Erzeugt eine XHTML Form. Alle
  72. <code>$attribs</code> werden als XHTML Attribute des Form Tags escaped und
  73. dargestellt. Wenn <code>$content</code> vorhanden und kein boolsches false ist,
  74. dann wird dieser Inhalt innerhalb der Start und End Form Tags dargestellt werden;
  75. wenn <code>$content</code> ein boolsches false ist (der Standard), wird nur das
  76. beginnende Formtag erzeugt.
  77. </para></listitem>
  78. <listitem><para>
  79. <code>formButton($name, $value, $attribs)</code>: Erstellt ein
  80. &lt;button /&gt; Element.
  81. </para></listitem>
  82. <listitem>
  83. <para>
  84. <code>formCheckbox($name, $value, $attribs, $options):</code>
  85. Erstellt ein &lt;input type="checkbox" /&gt; Element.
  86. </para>
  87. <para>
  88. Standardmäßig, wenn kein $value angegeben und keine $options vorhanden sind,
  89. wird '0' als ungecheckter Wert, und '1' als gecheckter Wert angenommen. Wenn
  90. ein $value übergeben wird, aber keine $options vorhanden sind, wird der
  91. gecheckte Wert and der übergebene Wert angenommen.
  92. </para>
  93. <para>
  94. $options sollte ein Array sein. Wenn das Array indiziert ist, ist der erste
  95. Wert der gecheckte Wert, und der zweite der ungecheckte Wert; alle anderen
  96. Werte werden ignoriert. Es kann auch ein assoziatives Array mit den Schlüsseln
  97. 'checked' und 'unChecked' übergeben werden.
  98. </para>
  99. <para>
  100. Wenn $options übergeben wurden und $value mit dem gecheckten Wert
  101. übereinstimmt, dann wird das Element als gecheckt markiert. Das Element kann
  102. auch als gecheckt oder ungecheckt markiert werden indem ein boolscher Wert
  103. für das Attribut 'checked' übergeben wird.
  104. </para>
  105. <para>
  106. Das obige wird möglicherweise am besten mit einigen Beispielen zusammengefasst:
  107. </para>
  108. <programlisting role="php"><![CDATA[
  109. // '1' und '0' als gecheckte/ungecheckte Optionen; nicht gecheckt
  110. echo $this->formCheckbox('foo');
  111. // '1' und '0' als gecheckte/ungecheckte Optionen; gecheckt
  112. echo $this->formCheckbox('foo', null, array('checked' => true));
  113. // 'bar' und '0' als gecheckte/ungecheckte Optionen; nicht gecheckt
  114. echo $this->formCheckbox('foo', 'bar');
  115. // 'bar' und '0' als gecheckte/ungecheckte Optionen; gecheckt
  116. echo $this->formCheckbox('foo', 'bar', array('checked' => true));
  117. // 'bar' und 'baz' als gecheckte/ungecheckte Optionen; nicht gecheckt
  118. echo $this->formCheckbox('foo', null, null, array('bar', 'baz');
  119. // 'bar' und 'baz' als gecheckte/ungecheckte Optionen; nicht gecheckt
  120. echo $this->formCheckbox('foo', null, null, array(
  121. 'checked' => 'bar',
  122. 'unChecked' => 'baz'
  123. ));
  124. // 'bar' und 'baz' als gecheckte/ungecheckte Optionen; gecheckt
  125. echo $this->formCheckbox('foo', 'bar', null, array('bar', 'baz');
  126. echo $this->formCheckbox('foo',
  127. null,
  128. array('checked' => true),
  129. array('bar', 'baz');
  130. // 'bar' und 'baz' als gecheckte/ungecheckte Optionen; nicht gecheckt
  131. echo $this->formCheckbox('foo', 'baz', null, array('bar', 'baz');
  132. echo $this->formCheckbox('foo',
  133. null,
  134. array('checked' => false),
  135. array('bar', 'baz');
  136. ]]></programlisting>
  137. <para>
  138. In allen Fällen, wird das Markup einem versteckten Element mit dem
  139. nicht gecheckten Wert vorangestellt; auf diesem Weg erhält man
  140. trotzdem einen gültigen Wert von der Form selbst wenn der Wert nicht
  141. gecheckt wird.
  142. </para>
  143. </listitem>
  144. <listitem>
  145. <para>
  146. <code>formErrors($errors, $options):</code> Erzeugt eine ungeordnete XHTML
  147. Liste und zeigt Fehler an. <code>$errors</code> sollte ein String oder ein
  148. Array von Strings sein; <code>$options</code> sollte irgendein Attribut sein
  149. das im beginnenden List Tag platziert werden soll.
  150. </para>
  151. <para>
  152. Es kann alternativer beginnender, schließender und seperierter Inhalt
  153. spezifiziert werden wenn Fehler dargestellt werden durch aufruf von
  154. verschiedenen Methoden auf dem Helfer:
  155. </para>
  156. <itemizedlist>
  157. <listitem><para>
  158. <code>setElementStart($string)</code>; Standard ist
  159. '&lt;ul class="errors"%s"&gt;&lt;li&gt;', wobei %s mit den in
  160. <code>$options</code> spezifizierten Attributen ersetzt wird.
  161. </para></listitem>
  162. <listitem><para>
  163. <code>setElementSeparator($string)</code>; Standard ist
  164. '&lt;/li&gt;&lt;li&gt;'.
  165. </para></listitem>
  166. <listitem><para>
  167. <code>setElementEnd($string)</code>; Standard ist
  168. '&lt;/li&gt;&lt;/ul&gt;'.
  169. </para></listitem>
  170. </itemizedlist>
  171. </listitem>
  172. <listitem><para>
  173. <code>formFile($name, $attribs)</code>: Erstellt ein
  174. &lt;input type="file" /&gt; Element.
  175. </para></listitem>
  176. <listitem><para>
  177. <code>formHidden($name, $value, $attribs)</code>: Erstellt ein
  178. &lt;input type="hidden" /&gt; Element.
  179. </para></listitem>
  180. <listitem><para>
  181. <code>formLabel($name, $value, $attribs)</code>: Erstellt ein
  182. &lt;label&gt; Element, setzt das <code>for</code> Attribut auf
  183. <code>$name</code>, und den aktuellen Labeltext auf
  184. <code>$value</code>. Wenn <code>disable</code> an
  185. <code>attribs</code> übergeben wird, wird nichts zurückgegeben.
  186. </para></listitem>
  187. <listitem><para>
  188. <code>formMultiCheckbox($name, $value, $attribs, $options, $listsep):</code>
  189. Erstellt eine Liste von Checkboxen. <code>$options</code> sollte ein assoziatives
  190. Array sein und kann beliebig tief werden. <code>$value</code> kann ein einzelner
  191. Wert oder ein Array von ausgewählten Werten sein die Schlüsseln im
  192. <code>$options</code> Array entsprechen. <code>$listsep</code> ist standardmäßig
  193. ein HTML Break ("&lt;br /&gt;"). Standardmäßig wird dieses Element als Array
  194. behandelt; alle Checkboxen teilen den gleichen Namen, und werden als Array
  195. übertragen.
  196. </para></listitem>
  197. <listitem><para>
  198. <code>formPassword($name, $value, $attribs)</code>: Erstellt ein
  199. &lt;input type="password" /&gt; Element.
  200. </para></listitem>
  201. <listitem><para>
  202. <code>formRadio($name, $value, $attribs, $options)</code>: Erstellt eine Reihe von
  203. &lt;input type="radio" /&gt; Elementen, eine für jeden der $options Elemente.
  204. Im $options Array ist der Elementschlüssel der Wert und der Elementwert die
  205. Bezeichnung des Radio-Buttons. Der $value Radiobutton wird für dich vorgewählt.
  206. </para></listitem>
  207. <listitem><para>
  208. <code>formReset($name, $value, $attribs)</code>: Erstellt ein
  209. &lt;input type="reset" /&gt; Element.
  210. </para></listitem>
  211. <listitem><para>
  212. <code>formSelect($name, $value, $attribs, $options)</code>: Erstellt einen
  213. &lt;select&gt;...&lt;/select&gt; block mit einer &lt;option&gt;one für jedes
  214. $options Element. Im $options Array ist der Elementschlüssel der Optionswert und
  215. der Elementwert die Optionsbezeichnung. Die $value Optionen werden für dich
  216. vorgewählt.
  217. </para></listitem>
  218. <listitem><para>
  219. <code>formSubmit($name, $value, $attribs)</code>: Erstellt ein
  220. &lt;input type="submit" /&gt; Element.
  221. </para></listitem>
  222. <listitem><para>
  223. <code>formText($name, $value, $attribs)</code>: Erstellt ein
  224. &lt;input type="text" /&gt; Element.
  225. </para></listitem>
  226. <listitem><para>
  227. <code>formTextarea($name, $value, $attribs)</code>: Erstellt einen
  228. &lt;textarea&gt;...&lt;/textarea&gt; Block.
  229. </para></listitem>
  230. <listitem><para>
  231. <code>url($urlOptions, $name, $reset):</code> Erstelle einen URL String basierend
  232. auf dem Namen der Route. <code>$urlOptions</code> sollte ein assoziatives Array von
  233. Schlüßel/Werte Paaren sein, welche bon der speziellen Route verwendet wird.
  234. </para></listitem>
  235. <listitem><para>
  236. <code>htmlList($items, $ordered, $attribs, $escape):</code> erzeugt ungeordnete und
  237. geordnete Listen welche auf den <code>$items</code> basieren die übergeben wurden.
  238. Wenn <code>$items</code> ein multidimensionales Array ist, wird eine verschachtelte
  239. Liste gebaut. Wenn das <code>$escape</code> Flag true ist (standard), werden
  240. individuelle Abschnitte escaped durch Verwendung des Escaping Mechanismus der im
  241. View Objekt registriert wurde; ein false Wert wird übergeben wenn Markups in den
  242. Listen gewünscht werden.
  243. </para></listitem>
  244. </itemizedlist>
  245. <para>
  246. Die Verwendung dieser Helfer in deinem View Skript ist sehr einfach, hier ist ein
  247. Beispiel. Beachte, dass du diese Helfer nur aufzurufen brauchst; sie werden automatisch
  248. geladen und instanziiert, sobald sie benötigt werden.
  249. </para>
  250. <programlisting role="php"><![CDATA[
  251. // Innerhalb deines View Skriptes, verweist $this auf die Zend_View
  252. // Instanz.
  253. //
  254. // Sagen wir, dass du bereits eine Serie von Auswahlwerten der Variable
  255. // $countries in Form eines Arrays zugewiesen hast
  256. // ('us' => 'United States', 'il' => 'Israel', 'de' => 'Germany')
  257. ?>
  258. <form action="action.php" method="post">
  259. <p><label>Deine Email:
  260. <?php echo $this->formText('email', 'you@example.com', array('size' => 32)) ?>
  261. </label></p>
  262. <p><label>Dein Land:
  263. <?php echo $this->formSelect('country', 'us', null, $this->countries) ?>
  264. </label></p>
  265. <p><label>Möchtest Du hinzugefügt werden?
  266. <?php echo $this->formCheckbox('opt_in', 'yes', null, array('yes', 'no')) ?>
  267. </label></p>
  268. </form>
  269. ]]></programlisting>
  270. <para>
  271. Die Ausgabe des View Skriptes wird in etwa so aussehen:
  272. </para>
  273. <programlisting role="php"><![CDATA[
  274. <form action="action.php" method="post">
  275. <p><label>Deine Email:
  276. <input type="text" name="email" value="you@example.com" size="32" />
  277. </label></p>
  278. <p><label>Dein Land:
  279. <select name="country">
  280. <option value="us" selected="selected">Amerika</option>
  281. <option value="il">Israel</option>
  282. <option value="de">Deutschland</option>
  283. </select>
  284. </label></p>
  285. <p><label>Möchtest Du hinzugefügt werden?
  286. <input type="hidden" name="opt_in" value="no" />
  287. <input type="checkbox" name="opt_in" value="yes" checked="checked" />
  288. </label></p>
  289. </form>
  290. ]]></programlisting>
  291. <xi:include href="Zend_View-Helpers-Action.xml" />
  292. <xi:include href="Zend_View-Helpers-Cycle.xml" />
  293. <xi:include href="Zend_View-Helpers-Partial.xml" />
  294. <xi:include href="Zend_View-Helpers-Placeholder.xml" />
  295. <xi:include href="Zend_View-Helpers-Doctype.xml" />
  296. <xi:include href="Zend_View-Helpers-HeadLink.xml" />
  297. <xi:include href="Zend_View-Helpers-HeadMeta.xml" />
  298. <xi:include href="Zend_View-Helpers-HeadScript.xml" />
  299. <xi:include href="Zend_View-Helpers-HeadStyle.xml" />
  300. <xi:include href="Zend_View-Helpers-HeadTitle.xml" />
  301. <xi:include href="Zend_View-Helpers-HtmlObject.xml" />
  302. <xi:include href="Zend_View-Helpers-InlineScript.xml" />
  303. <xi:include href="Zend_View-Helpers-Json.xml" />
  304. <xi:include href="Zend_View-Helpers-Navigation.xml" />
  305. <xi:include href="Zend_View-Helpers-Translate.xml" />
  306. </sect2>
  307. <sect2 id="zend.view.helpers.paths">
  308. <title>Helfer Pfade</title>
  309. <para>
  310. Wie bei den View Skripten kann der Controller für <classname>Zend_View</classname> auch einen
  311. Stapel an Pfaden festlegen, in dem nach Hilfsklassen gesucht werden soll. Standardmäßig
  312. sucht <classname>Zend_View</classname> in "Zend/View/Helper/*" nach Hilfsklassen. Du kannst
  313. <classname>Zend_View</classname> mit Hilfe der Methoden <code>setHelperPath()</code> und
  314. <code>addHelperPath()</code> mitteilen, auch in anderen Verzeichnissen zu suchen.
  315. Zusätzlich kann man einen Klassenpräfix angeben, um Helfer in dem bereit gestellten Pfad
  316. verwenden zu können, um eigene Namensräume für die Helferklassen zu verwenden.
  317. Standardmäßig wird 'Zend_View_Helper_' angenommen, wenn kein Präfix angegeben wird.
  318. </para>
  319. <programlisting role="php"><![CDATA[
  320. $view = new Zend_View();
  321. // Setze den Pfad auf /path/to/more/helpers, mit dem Präfix 'My_View_Helper'
  322. $view->setHelperPath('/path/to/more/helpers', 'My_View_Helper');
  323. ]]></programlisting>
  324. <para>
  325. Durch Verwendung der <code>addHelperPath()</code> Methode können die Pfade "gestapelt"
  326. werden. Wenn du Pfade zu diesem Stapelspeicher hinzufügst, wird <classname>Zend_View</classname>
  327. im zuletzt hinzugefügten Pfad nach der angeforderten Hilfsklasse schauen. Dies erlaubt
  328. dir, zu den vorhandenen Helfern weitere hinzufügen oder diese durch eigene zu ersetzen.
  329. </para>
  330. <programlisting role="php"><![CDATA[
  331. $view = new Zend_View();
  332. // Füge /path/to/some/helpers mit Klassenpräfix 'My_View_Helper' hinzu
  333. $view->addHelperPath('/path/to/some/helpers', 'My_View_Helper');
  334. // Füge /other/path/to/helpers mit Klassenpräfix 'Your_View_Helper' hinzu
  335. $view->addHelperPath('/other/path/to/helpers', 'Your_View_Helper');
  336. // wenn nun $this->helperName() aufgerufen wird, wird Zend_View zuerst nach
  337. // "/path/to/some/helpers/HelperName" mit dem Klassennamen
  338. // "Your_View_Helper_HelperName", dann nach
  339. // "/other/path/to/helpers/HelperName.php" mit dem Klassennamen
  340. // "My_View_Helper_HelperName", und zuletzt nach
  341. // "Zend/View/Helpers/HelperName.php" mit dem Klassennamen
  342. // "Zend_View_Helper_HelperName" schauen.
  343. ]]></programlisting>
  344. </sect2>
  345. <sect2 id="zend.view.helpers.custom">
  346. <title>Eigene Helfer schreiben</title>
  347. <para>
  348. Eigene Helfer zu schreiben ist einfach; du mußt nur diese Regeln befolgen:
  349. </para>
  350. <itemizedlist>
  351. <listitem><para>
  352. Wärend das nicht strikt notwendig ist, ist es empfohlen entweder
  353. <classname>Zend_View_Helper_Interface</classname> zu implementieren oder
  354. <classname>Zend_View_Helper_Abstract</classname> zu erweitern wenn eigene Helfer erstellt werden.
  355. Eingeführt mit 1.6.0, definieren diese einfach die <code>setView()</code> Methode;
  356. trotzdem, in kommenden Releases, ist es geplant ein Strategy Pattern zu implementieren das
  357. vieles der Namensschemas einfacher mach wie anbei beschrieben. Wenn darauf aufgebaut wird
  358. hilft das, das der eigene Code Zukunftssicher ist.
  359. </para></listitem>
  360. <listitem><para>
  361. Der Klassenname muss mindestens auf den Helfernamen unter Verwendung der MixedCaps
  362. selber enden. Wenn du z.B. einen Helfer mit Namen "specialPurpose" schreibst, muss
  363. der Klassenname mindestens "SpecialPurpose" lauten. Man kann, und sollte, dem
  364. Klassennamen einen Präfix geben und es wird empfohlen, 'View_Helper' als Teil des
  365. Präfix zu verwenden: "My_View_Helper_SpecialPurpose" (man muss den Präfix mit oder
  366. oder abschließenden Unterstrich an <code>addHelperPath()</code> oder
  367. <code>setHelperPath()</code> übergeben).
  368. </para></listitem>
  369. <listitem><para>
  370. Die Klasse muss eine öffentliche Methode mit dem Namen des Helfers haben. Dies ist
  371. die Methode, welche vom View Skript durch "$this->specialPurpose()" aufgerufen wird.
  372. In unserem "specialPurpose" Beispiel, würde die notwendige Deklaration dieser
  373. Methode "public function specialPurpose()" lauten.
  374. </para></listitem>
  375. <listitem><para>
  376. Im Allgemeinen sollte die Klasse keine Ausgaben durch echo(), print() oder auf
  377. andere Weise erstellen. Stattdessen sollte es die auszugebenen Werte zurückgeben.
  378. Die zurückgegebenen Werte sollten entsprechend maskiert werden.
  379. </para></listitem>
  380. <listitem><para>
  381. Diese Klasse muss sich in einer Datei befinden, die nach der Helfermethode benannt
  382. ist. Bezogen auf unser "specialPurpose" Beispiel, muss der Dateiname
  383. "SpecialPurpose.php" lauten.
  384. </para></listitem>
  385. </itemizedlist>
  386. <para>
  387. Platziere die Hilfsklasse irgendwo in deinem Stapelspeicher für Hilfspfade und
  388. <classname>Zend_View</classname> wird den Helfer automatisch für dich laden, instanziieren,
  389. speichern und ausführen.
  390. </para>
  391. <para>
  392. Hier ist ein Beispiel für unseren <code>SpecialPurpose</code> Helfer:
  393. </para>
  394. <programlisting role="php"><![CDATA[
  395. class My_View_Helper_SpecialPurpose extends Zend_View_Helper_Abstract
  396. {
  397. protected $_count = 0;
  398. public function specialPurpose()
  399. {
  400. $this->_count++;
  401. $output = "Ich habe 'The Jerk' {$this->_count} Mal(e) gesehen.";
  402. return htmlspecialchars($output);
  403. }
  404. }
  405. ]]></programlisting>
  406. <para>
  407. Dann rufst du in einem View Skript den <code>SpecialPurpose</code> Helfer so oft auf,
  408. wie du möchtest; er wird einmal instanziiert und bleibt für die Lebensdauer der
  409. <classname>Zend_View</classname> Instanz bestehen.
  410. </para>
  411. <programlisting role="php"><![CDATA[
  412. // denke daran, dass $this in deinem View Skript auf die
  413. // Zend_View Instanz verweist.
  414. echo $this->specialPurpose();
  415. echo $this->specialPurpose();
  416. echo $this->specialPurpose();
  417. ]]></programlisting>
  418. <para>
  419. Die Ausgabe wird in etwa so aussehen:
  420. </para>
  421. <programlisting role="php"><![CDATA[
  422. Ich habe 'The Jerk' 1 Mal(e) gesehen.
  423. Ich habe 'The Jerk' 2 Mal(e) gesehen.
  424. Ich habe 'The Jerk' 3 Mal(e) gesehen.
  425. ]]></programlisting>
  426. <para>
  427. Hier und da ist es notwendig das aufrufende <classname>Zend_View</classname> Objekt aufzurufen --
  428. zum Beispiel, wenn es notwendig ist die registrierte Verschöüsselung zu verwenden, oder
  429. wenn ein anderes View Skript gerendert werden soll, als Teil des eigenen Helfers. Um
  430. Zugriff zum View Objekt zu erhalten, sollte die eigene Helfer Klasse eine
  431. <code>setView($view)</code> Methode wie folgt besitzen:
  432. </para>
  433. <programlisting role="php"><![CDATA[
  434. class My_View_Helper_ScriptPath
  435. {
  436. public $view;
  437. public function setView(Zend_View_Interface $view)
  438. {
  439. $this->view = $view;
  440. }
  441. public function scriptPath($script)
  442. {
  443. return $this->view->getScriptPath($script);
  444. }
  445. }
  446. ]]></programlisting>
  447. <para>
  448. Wenn die Helfer Klasse eine <code>setView()</code> Methode hat, wird diese aufgerufen wenn die
  449. Helfer Klasse das erste Mal instanziert wird, und das aktuelle View Objekt übergeben wird.
  450. Es liegt an einem selbst das Objekt in der Klasse zu fixieren, genau so wie herauszufinden
  451. wie auf dieses zugegriffen werden sollte.
  452. </para>
  453. <para>
  454. Wenn <classname>Zend_View_Helper_Abstract</classname> erweitert wird, muß diese Methode nicht selbst
  455. definiert werden da Sie schon vordefiniert ist.
  456. </para>
  457. </sect2>
  458. </sect1>
  459. <!--
  460. vim:se ts=4 sw=4 et:
  461. -->