migration-10.xml 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="migration.10">
  5. <title>Zend Framework 1.0</title>
  6. <para>
  7. Wenn man von einem älteren Release auf Zend Framework 1.0 oder höher hochrüstet sollte
  8. man die folgenden Migrations Hinweise beachten.
  9. </para>
  10. <sect2 id="migration.10.zend.controller">
  11. <title>Zend_Controller</title>
  12. <para>
  13. Die prinzipiellen Änderungen die durch 1.0.0RC1 angeboten werden sind die Einführung und
  14. standardmäßige Aktivierung des
  15. <link linkend="zend.controller.plugins.standard.errorhandler">ErrorHandler</link>
  16. Plugins und den
  17. <link linkend="zend.controller.actionhelpers.viewrenderer">ViewRenderer</link>
  18. Aktionhelfer. Bitte lies die Dokumentation jedes einzelnen gründlich um zu sehen wie sie
  19. arbeiten und welchen Effekt Sie auf die eigene Anwendung haben können.
  20. </para>
  21. <para>
  22. Der <classname>ErrorHandler</classname> Plugin läuft wärend der
  23. <methodname>postDispatch()</methodname> Prüfung auf Ausnahmen, und leitet zu einem
  24. spezifizierten Fehlerhandler Controller weiter. Solch ein Controller sollte in der
  25. eigenen Anwendung inkludiert werden. Er kann deaktiviert werden durch das setzen des
  26. Frontcontroller Parameters <property>noErrorHandler</property>:
  27. </para>
  28. <programlisting language="php"><![CDATA[
  29. $front->setParam('noErrorHandler', true);
  30. ]]></programlisting>
  31. <para>
  32. Der <classname>ViewRenderer</classname> Aktionhelfer automatisiert die Injizierung der
  33. View in den Aktioncontroller genauso wie das autorendern von Viewskripten basierend auf
  34. die aktuelle Aktion. Das primäre Problem dem man begegnen kann ist, wenn man Aktionen
  35. hat die keine View Skripte rendern und weder vorwärts- noch weiterleiten, da der
  36. <classname>ViewRenderer</classname> versucht ein View Skript zu Rendern basierend auf
  37. dem Aktionnamen.
  38. </para>
  39. <para>
  40. Es gibt verschiedene Strategien die man anwenden kann um den eigenen Code upzudaten. In
  41. kurzer Form, kann man global den <classname>ViewRenderer</classname> im eigenen
  42. Frontcontroller Bootstrap vor dem Abarbeiten ausschalten:
  43. </para>
  44. <programlisting language="php"><![CDATA[
  45. // Annahme das $front eine Instanz von Zend_Controller_Front ist
  46. $front->setParam('noViewRenderer', true);
  47. ]]></programlisting>
  48. <para>
  49. Trotzdem ist es keine gute Langzeitstrategie, da es auch bedeutet das man mehr Code
  50. schreiben muß.
  51. </para>
  52. <para>
  53. Wenn man bereit ist damit zu beginnen die <classname>ViewRenderer</classname>
  54. Funktionalität zu verwenden, gibt es verschiedene Dinge die man im eigenen
  55. Controllercode beachten muß. Zuerst muß auf die Aktionmethoden (die Methoden die mit
  56. 'Action' enden) geachtet werden, und ausgesucht werden was eine jede machen soll. Wenn
  57. nichts vom folgenden passiert, muß man Änderungen durchführen:
  58. </para>
  59. <itemizedlist>
  60. <listitem><para>Aufruf von <command>$this->render();</command></para></listitem>
  61. <listitem><para>Aufruf von <command>$this->_forward();</command></para></listitem>
  62. <listitem><para>Aufruf von <command>$this->_redirect();</command></para></listitem>
  63. <listitem>
  64. <para>Aufruf des <classname>Redirector</classname> Aktionhelfers</para>
  65. </listitem>
  66. </itemizedlist>
  67. <para>
  68. Die einfachste Änderung ist das Ausschalten des Auto-Rendering für diese Methode:
  69. </para>
  70. <programlisting language="php"><![CDATA[
  71. $this->_helper->viewRenderer->setNoRender();
  72. ]]></programlisting>
  73. <para>
  74. Wenn man herausfindet das keine der eigenen Aktionmethoden rendern, weiterleiten oder
  75. umleiten, wird man voraussichtlich die oben angeführte Zeile in die eigene
  76. <methodname>preDispatch()</methodname> oder <methodname>init()</methodname> Methode
  77. einfügen wollen:
  78. </para>
  79. <programlisting language="php"><![CDATA[
  80. public function preDispatch()
  81. {
  82. // Ausschalten des autorendern vom View Skript
  83. $this->_helper->viewRenderer->setNoRender()
  84. // .. andere Dinge tun...
  85. }
  86. ]]></programlisting>
  87. <para>
  88. Wenn <methodname>render()</methodname> aufgerufen wird, und man
  89. <link linkend="zend.controller.modular">die konventionelle Modulare Verzeichnis
  90. Struktur</link> verwendet, wird man den Code ändern wollen um Autorendern zu
  91. Verwenden:
  92. </para>
  93. <itemizedlist>
  94. <listitem>
  95. <para>
  96. Wenn man mehrere View Skripte in einer einzelnen Aktion rendert muß nichts
  97. geändert werden.
  98. </para>
  99. </listitem>
  100. <listitem>
  101. <para>
  102. Wenn man einfach <methodname>render()</methodname> ohne Argumente aufruft,
  103. können diese Zeilen entfernt werden.
  104. </para>
  105. </listitem>
  106. <listitem>
  107. <para>
  108. Wenn man <methodname>render()</methodname> mit Argumenten aufruft, und danach
  109. nicht irgendeine Bearbeitung durchführt oder mehrere View sktipe rendert, können
  110. diese Aufrufe zu <command>$this->_helper->viewRenderer();</command> geändert
  111. werden.
  112. </para>
  113. </listitem>
  114. </itemizedlist>
  115. <para>
  116. Wenn die konventionelle modulare Verzeichnisstruktur nicht verwendet wird, gibt es eine
  117. Vielzahl von Methoden für das Setzen des View Basispfades und der Skript
  118. Pfadspezifikationen so das man den <classname>ViewRenderer</classname> verwenden kann.
  119. Bitte lies die <link linkend="zend.controller.actionhelpers.viewrenderer">ViewRenderer
  120. Dokumentation</link> für Informationen über diese Methoden.
  121. </para>
  122. <para>
  123. Wenn ein View Objekt von der Registry verwendet, oder das eigene View Objekt verändert,
  124. oder eine andere View Implementation verwendet wird, dann wird man den
  125. <classname>ViewRenderer</classname> in diesem Objekt injiziieren wollen. Das kann ganz
  126. einfach jederzeit durchgeführt werden.
  127. </para>
  128. <itemizedlist>
  129. <listitem>
  130. <para>
  131. Vor dem Verarbeiten einer Frontcontroller Instanz:
  132. </para>
  133. <programlisting language="php"><![CDATA[
  134. // Annahme das $view bereits definiert wurde
  135. $viewRenderer = new Zend_Controller_Action_Helper_ViewRenderer($view);
  136. Zend_Controller_Action_HelperBroker::addHelper($viewRenderer);
  137. ]]></programlisting>
  138. </listitem>
  139. <listitem>
  140. <para>
  141. Jederzeit wärend des Bootstrap Prozesses:
  142. </para>
  143. <programlisting language="php"><![CDATA[
  144. $viewRenderer =
  145. Zend_Controller_Action_HelperBroker::getStaticHelper('viewRenderer');
  146. $viewRenderer->setView($view);
  147. ]]></programlisting>
  148. </listitem>
  149. </itemizedlist>
  150. <para>
  151. Es gibt viele Wege den <classname>ViewRenderer</classname> zu modifizieren inklusive dem
  152. Setzen eines anderen View Skripts zum Rendern, dem Spezifizieren von Veränderungen für
  153. alle veränderbaren Elemente eines View Skript Pfades (inklusive der Endung), dem
  154. Auswählen eines Antwort-benannten Segments zur Anpassung und mehr. Wenn die
  155. konventionelle modulare Verzeichnisstruktur nicht verwendet wird, kann noch immer eine
  156. andere Pfad Spezifikation mit dem <classname>ViewRenderer</classname> zugeordnet werden.
  157. </para>
  158. <para>
  159. Wir empfehlen die Adaptierung des eigenen Codes um den
  160. <classname>ErrorHandler</classname> und <classname>ViewRenderer</classname> zu verwenden
  161. da diese neue Kernfunktionalitäten sind.
  162. </para>
  163. </sect2>
  164. <sect2 id="migration.10.zend.currency">
  165. <title>Zend_Currency</title>
  166. <para>
  167. Die Erstellung von <classname>Zend_Currency</classname> wurde vereinfacht.
  168. Es muß nicht länger ein Skript angegeben oder auf <constant>NULL</constant> gesetzt
  169. werden. Der optionale script Parameter ist jetzt eine Option welche durch die
  170. <methodname>setFormat()</methodname> Methode gesetzt werden kann.
  171. </para>
  172. <programlisting language="php"><![CDATA[
  173. $currency = new Zend_Currency($currency, $locale);
  174. ]]></programlisting>
  175. <para>
  176. Die <methodname>setFormat()</methodname> Methode nimmt jetzt ein Array von Optionen.
  177. Diese Optionen werden permanent gesetzt und überschreiben alle vorher gesetzten Werte.
  178. Auch eine neue Option 'precision' wurde integriert. Die folgenden Optionen wurden
  179. überarbeitet:
  180. </para>
  181. <itemizedlist mark='opencircle'>
  182. <listitem>
  183. <para><emphasis>position</emphasis>: Ersetzt den alten 'rules' Parameter.</para>
  184. </listitem>
  185. <listitem>
  186. <para><emphasis>script</emphasis>: Ersetzt den alten 'script' Parameter.</para>
  187. </listitem>
  188. <listitem>
  189. <para>
  190. <emphasis>format</emphasis>: Ersetzt den alten 'locale' Parameter welcher keine
  191. neue Währung, sondern nur das Format der Nummern setzt.
  192. </para>
  193. </listitem>
  194. <listitem>
  195. <para><emphasis>display</emphasis>: Ersetzt den alten 'rules' Parameter.</para>
  196. </listitem>
  197. <listitem><para><emphasis>precision</emphasis>: Neuer Parameter.</para></listitem>
  198. <listitem>
  199. <para>
  200. <emphasis>name</emphasis>: Ersetzt den alten 'rules' Parameter. Setzt den
  201. vollständigen Namen der Währung.
  202. </para>
  203. </listitem>
  204. <listitem><para><emphasis>currency</emphasis>: Neuer Parameter.</para></listitem>
  205. <listitem><para><emphasis>symbol</emphasis>: Neuer Parameter.</para></listitem>
  206. </itemizedlist>
  207. <programlisting language="php"><![CDATA[
  208. $currency->setFormat(array $options);
  209. ]]></programlisting>
  210. <para>
  211. Die <methodname>toCurrency()</methodname> Methode unterstützt die optionalen 'script'
  212. und 'locale' Parameter nicht mehr. Stattdessen nimmt sie ein Array von Optionen welche
  213. die selben Schlüssel enthalten können wie die <methodname>setFormat()</methodname>
  214. Methode.
  215. </para>
  216. <programlisting language="php"><![CDATA[
  217. $currency->toCurrency($value, array $options);
  218. ]]></programlisting>
  219. <para>
  220. Die Methoden <methodname>getSymbol()</methodname>,
  221. <methodname>getShortName()</methodname>, <methodname>getName()</methodname>,
  222. <methodname>getRegionList()</methodname> und <methodname>getCurrencyList()</methodname>
  223. sind nicht länger statisch und können vom Objekt aus aufgerufen werden. Die geben den
  224. aktuell gesetzten Wert des Objekts zurück wenn kein Parameter gesetzt wurde.
  225. </para>
  226. </sect2>
  227. </sect1>