Zend_Layout-Options.xml 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.layout.options">
  5. <title>Zend_Layout Konfigurations Optionen</title>
  6. <para>
  7. <classname>Zend_Layout</classname> hat eine Variation an Konfigurations Optionen. Diese
  8. können durch den Aufruf entsprechender Zugriffsmethoden gesetzt werden, durch die Übergabe
  9. eines Arrays oder <classname>Zend_Config</classname> Objektes an den Konstruktor oder
  10. <methodname>startMvc()</methodname>, durch die Übergabe eines Arrays von Optionen an
  11. <methodname>setOptions()</methodname>, oder der Übergabe eines
  12. <classname>Zend_Config</classname> Objektes an <methodname>setConfig()</methodname>.
  13. </para>
  14. <itemizedlist>
  15. <listitem>
  16. <para>
  17. <emphasis>layout</emphasis>: Das Layout das verwendet werden soll. Verwendet die
  18. aktuelle Beugung um den Namen, der dem entsprechenden Layout View Skript angegeben
  19. wurde, aufzulösen. Standardmäßig ist dieser Wert 'layout' und wird zu 'layout.phtml'
  20. aufgelöst. Zugriffsmethoden sind <methodname>setLayout()</methodname> und
  21. <methodname>getLayout()</methodname>.
  22. </para>
  23. </listitem>
  24. <listitem>
  25. <para>
  26. <emphasis>layoutPath</emphasis>: Der Basispfad zu den Layout View Skripten.
  27. Zugriffsmethoden sind <methodname>setLayoutPath()</methodname> und
  28. <methodname>getLayoutPath()</methodname>.
  29. </para>
  30. </listitem>
  31. <listitem>
  32. <para>
  33. <emphasis>contentKey</emphasis>: Die Layout Variable die für Standardinhalte
  34. verwendet wird (wenn mit dem <acronym>MVC</acronym> verwendet). Der Standardwert ist
  35. 'content'. Zugriffsmethoden sind <methodname>setContentKey()</methodname> und
  36. <methodname>getContentKey()</methodname>.
  37. </para>
  38. </listitem>
  39. <listitem>
  40. <para>
  41. <emphasis>mvcSuccessfulActionOnly</emphasis>: Wenn <acronym>MVC</acronym> verwendet
  42. wird, dann wird das Layout nicht dargestellt wenn eine Aktion eine Ausnahme wirft
  43. und dieses Flag <constant>TRUE</constant> ist (das wird verwendet um zu verhindern
  44. dass das Layout doppelt dargestellt wird wenn das <link
  45. linkend="zend.controller.plugins.standard.errorhandler">ErrorHandler
  46. Plugin</link> verwendet wird. Standardmäßig ist dieses Flag
  47. <constant>TRUE</constant>. Zugriffsmethoden sind
  48. <methodname>setMvcSuccessfulActionOnly()</methodname> und
  49. <methodname>getMvcSuccessfulActionOnly()</methodname>.
  50. </para>
  51. </listitem>
  52. <listitem>
  53. <para>
  54. <emphasis>view</emphasis>: Das View Objekt das für die Darstellung verwendet wird.
  55. Wenn mit <acronym>MVC</acronym> verwendet, dann versucht
  56. <classname>Zend_Layout</classname> das View Objekt zu verwenden das mit <link
  57. linkend="zend.controller.actionhelpers.viewrenderer">dem ViewRenderer</link>
  58. registriert wurde wenn kein explizites View Objekt übergeben wurde. Zugriffsmethoden
  59. sind <methodname>setView()</methodname> und <methodname>getView()</methodname>.
  60. </para>
  61. </listitem>
  62. <listitem>
  63. <para>
  64. <emphasis>helperClass</emphasis>: Die Action Helfer Klasse die verwendet wird wenn
  65. <classname>Zend_Layout</classname> mit den <acronym>MVC</acronym> Komponenten
  66. verwendet wird. Standardmäßig ist das
  67. <classname>Zend_Layout_Controller_Action_Helper_Layout</classname>. Zugriffsmethoden
  68. sind <methodname>setHelperClass()</methodname> und
  69. <methodname>getHelperClass()</methodname>.
  70. </para>
  71. </listitem>
  72. <listitem>
  73. <para>
  74. <emphasis>pluginClass</emphasis>: Das Front Controller Plugin das verwendet wird
  75. wenn <classname>Zend_Layout</classname> mit den <acronym>MVC</acronym> Komponenten
  76. verwendet wird. Standardmäßig ist das
  77. <classname>Zend_Layout_Controller_Plugin_Layout</classname>. Zugriffsmethoden sind
  78. <methodname>setPluginClass()</methodname> und
  79. <methodname>getPluginClass()</methodname>.
  80. </para>
  81. </listitem>
  82. <listitem>
  83. <para>
  84. <emphasis>inflector</emphasis>: Die Beugung die verwendet werden soll wenn Layout
  85. Namen zu Layout Skript Pfaden aufgelöst werden; siehe <link
  86. linkend="zend.layout.advanced.inflector">die <classname>Zend_Layout</classname>
  87. Beugungs Dokumentation für weitere Details</link>. Zugriffsmethoden sind
  88. <methodname>setInflector()</methodname> und <methodname>getInflector()</methodname>.
  89. </para>
  90. </listitem>
  91. </itemizedlist>
  92. <note>
  93. <title>HelferKlasse und PluginKlasse müssen an startMvc() übergeben werden</title>
  94. <para>
  95. Damit die <property>helperClass</property> und <property>pluginClass</property>
  96. Einstellungen wirken, müssen diese als Option an <methodname>startMvc()</methodname>
  97. übergeben werden; wenn sie später gesetzt werden, haben Sie keinen Effekt.
  98. </para>
  99. </note>
  100. <sect2 id="zend.layout.options.examples">
  101. <title>Beispiele</title>
  102. <para>
  103. Die folgenden Beispiele nehmen das folgende <varname>$options</varname> Array und
  104. <varname>$config</varname> Objekt an:
  105. </para>
  106. <programlisting language="php"><![CDATA[
  107. $options = array(
  108. 'layout' => 'foo',
  109. 'layoutPath' => '/path/to/layouts',
  110. 'contentKey' => 'CONTENT', // Ignoriert wenn MVC nicht verwendet wird
  111. );
  112. ]]></programlisting>
  113. <programlisting language="php"><![CDATA[
  114. /**
  115. [layout]
  116. layout = "foo"
  117. layoutPath = "/path/to/layouts"
  118. contentKey = "CONTENT"
  119. */
  120. $config = new Zend_Config_Ini('/path/to/layout.ini', 'layout');
  121. ]]></programlisting>
  122. <example id="zend.layout.options.examples.constructor">
  123. <title>Optionen an den Konstruktor oder startMvc() übergeben</title>
  124. <para>
  125. Beide, der Konstruktor und die statische <methodname>startMvc()</methodname> Methode
  126. akzeptieren entweder ein Array von Optionen oder ein
  127. <classname>Zend_Config</classname> Objekt mit Optionen um die
  128. <classname>Zend_Layout</classname> Instanz zu konfigurieren.
  129. </para>
  130. <para>
  131. Zuerst zeigen wir die Übergabe eines Arrays:
  132. </para>
  133. <programlisting language="php"><![CDATA[
  134. // Konstruktor verwenden:
  135. $layout = new Zend_Layout($options);
  136. // startMvc() verwenden:
  137. $layout = Zend_Layout::startMvc($options);
  138. ]]></programlisting>
  139. <para>
  140. Und jetzt die Verwendung eines Config Objekts:
  141. </para>
  142. <programlisting language="php"><![CDATA[
  143. $config = new Zend_Config_Ini('/path/to/layout.ini', 'layout');
  144. // Konstruktor verwenden:
  145. $layout = new Zend_Layout($config);
  146. // startMvc() verwenden:
  147. $layout = Zend_Layout::startMvc($config);
  148. ]]></programlisting>
  149. <para>
  150. Grundsätzlich ist das der einfachste Weg um die <classname>Zend_Layout</classname>
  151. Instanz anzupassen.
  152. </para>
  153. </example>
  154. <example id="zend.layout.options.examples.setoptionsconfig">
  155. <title>setOption() und setConfig() verwenden</title>
  156. <para>
  157. Machmal ist es notwendig das <classname>Zend_Layout</classname> Objekt zu
  158. Konfigurieren nachdem es instanziiert wurde; <methodname>setOptions()</methodname>
  159. und <methodname>setConfig()</methodname> bieten einen schnellen und einfachen Weg
  160. das zu tun:
  161. </para>
  162. <programlisting language="php"><![CDATA[
  163. // Ein Array von Optionen verwenden:
  164. $layout->setOptions($options);
  165. // Ein Zend_Config Objekt verwenden:
  166. $layout->setConfig($options);
  167. ]]></programlisting>
  168. <para>
  169. Es ist zu beachten das einige Optionen, wie <property>pluginClass</property> und
  170. <property>helperClass</property>, keinen Effekt haven wenn Sie mit Hilfe dieser
  171. Methode übergeben werden; sie müssen mit dem Konstruktor oder der
  172. <methodname>startMvc()</methodname> Methode übergeben werden.
  173. </para>
  174. </example>
  175. <example id="zend.layout.options.examples.accessors">
  176. <title>Zugriffsmethoden verwenden</title>
  177. <para>
  178. Letztendlich kann die <classname>Zend_Layout</classname> Instanz auch über
  179. Zugriffsmetoden konfiguriert werden. Alle Zugriffsmethoden implementieren ein
  180. Flüssiges Interface, was bedeutet das Ihre Aufrufe gekettet werden können:
  181. </para>
  182. <programlisting language="php"><![CDATA[
  183. $layout->setLayout('foo')
  184. ->setLayoutPath('/path/to/layouts')
  185. ->setContentKey('CONTENT');
  186. ]]></programlisting>
  187. </example>
  188. </sect2>
  189. </sect1>