Zend_Layout-Options.xml 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect1 id="zend.layout.options">
  5. <title>Zend_Layout の設定オプション</title>
  6. <para>
  7. <classname>Zend_Layout</classname> にはさまざまな設定オプションがあります。
  8. オプションを設定する方法には次のようなものがあります。
  9. まずアクセサメソッドをコールすること、
  10. 次に配列や <classname>Zend_Config</classname> オブジェクトをコンストラクタあるいは
  11. <methodname>startMvc()</methodname> に渡すこと、
  12. オプションの配列を <methodname>setOptions()</methodname> に渡すこと、
  13. そして <classname>Zend_Config</classname> オブジェクトを <methodname>setConfig()</methodname>
  14. に渡すことです。
  15. </para>
  16. <itemizedlist>
  17. <listitem><para>
  18. <emphasis>layout</emphasis>:
  19. 使用するレイアウト。現在のインフレクタを使用して名前を解決し、
  20. 適切なレイアウトビュースクリプトを使用します。デフォルトでは、この値は
  21. 'layout' で、'layout.phtml' に解決されます。
  22. アクセサは <methodname>setLayout()</methodname> と <methodname>getLayout()</methodname> です。
  23. </para></listitem>
  24. <listitem><para>
  25. <emphasis>layoutPath</emphasis>:
  26. レイアウトビュースクリプトの基底パス。
  27. アクセサは <methodname>setLayoutPath()</methodname> と
  28. <methodname>getLayoutPath()</methodname> です。
  29. </para></listitem>
  30. <listitem><para>
  31. <emphasis>contentKey</emphasis>:
  32. デフォルトのコンテンツに使用するレイアウト変数
  33. (<acronym>MVC</acronym> と組み合わせて使用する場合のみ)。
  34. デフォルト値は 'content' です。
  35. アクセサは <methodname>setContentKey()</methodname> と
  36. <methodname>getContentKey()</methodname> です。
  37. </para></listitem>
  38. <listitem><para>
  39. <emphasis>mvcSuccessfulActionOnly</emphasis>:
  40. <acronym>MVC</acronym> とともに使用します。このフラグを <constant>TRUE</constant> にすると、
  41. アクションが例外をスローした際にレイアウトをレンダリングしません
  42. (これにより、
  43. <link linkend="zend.controller.plugins.standard.errorhandler">ErrorHandler
  44. プラグイン</link> を使用している際の二重レンダリング問題を回避します)。
  45. デフォルトでは、このフラグは <constant>TRUE</constant> です。
  46. アクセサは <methodname>setMvcSuccessfulActionOnly()</methodname> と
  47. <methodname>getMvcSuccessfulActionOnly()</methodname> です。
  48. </para></listitem>
  49. <listitem><para>
  50. <emphasis>view</emphasis>:
  51. レンダリングの際に使用するビューオブジェクト。
  52. <acronym>MVC</acronym> と組み合わせて使用した場合、
  53. ビューオブジェクトを明示しなければ <classname>Zend_Layout</classname> は
  54. <link linkend="zend.controller.actionhelpers.viewrenderer">
  55. ViewRenderer</link>
  56. で登録されたビューオブジェクトを使用します。
  57. アクセサは <methodname>setView()</methodname> と
  58. <methodname>getView()</methodname> です。
  59. </para></listitem>
  60. <listitem><para>
  61. <emphasis>helperClass</emphasis>:
  62. <classname>Zend_Layout</classname> を <acronym>MVC</acronym>
  63. コンポーネントを組み合わせて使用する際のアクションヘルパークラス。
  64. デフォルトでは、これは
  65. <classname>Zend_Layout_Controller_Action_Helper_Layout</classname> です。
  66. アクセサは <methodname>setHelperClass()</methodname> と
  67. <methodname>getHelperClass()</methodname> です。
  68. </para></listitem>
  69. <listitem><para>
  70. <emphasis>pluginClass</emphasis>:
  71. <classname>Zend_Layout</classname> を <acronym>MVC</acronym>
  72. コンポーネントを組み合わせて使用する際のフロントコントローラプラグインクラス。
  73. デフォルトでは、これは
  74. <classname>Zend_Layout_Controller_Plugin_Layout</classname> です。
  75. アクセサは <methodname>setPluginClass()</methodname> と
  76. <methodname>getPluginClass()</methodname> です。
  77. </para></listitem>
  78. <listitem><para>
  79. <emphasis>inflector</emphasis>:
  80. レイアウト名をレイアウトビュースクリプトのパスに解決する際に使用するインフレクタ。
  81. 詳細は <link
  82. linkend="zend.layout.advanced.inflector">
  83. <classname>Zend_Layout</classname> インフレクタのドキュメント
  84. </link> を参照ください。
  85. アクセサは <methodname>setInflector()</methodname> と
  86. <methodname>getInflector()</methodname> です。
  87. </para></listitem>
  88. </itemizedlist>
  89. <note>
  90. <title>helperClass と pluginClass は startMvc() で渡す必要がある</title>
  91. <para>
  92. <property>helperClass</property> と
  93. <property>pluginClass</property> の設定を有効にするには、
  94. <methodname>startMvc()</methodname> のオプションで指定する必要があります。
  95. それ以降で指定しても効果はありません。
  96. </para>
  97. </note>
  98. <sect2 id="zend.layout.options.examples">
  99. <title>例</title>
  100. <para>
  101. 以下の例では、次のような <code>$options</code>
  102. 配列と <code>$config</code> オブジェクトを前提としています。
  103. </para>
  104. <programlisting language="php"><![CDATA[
  105. $options = array(
  106. 'layout' => 'foo',
  107. 'layoutPath' => '/path/to/layouts',
  108. 'contentKey' => 'CONTENT', // MVC を使わない場合は無視されます
  109. );
  110. ]]></programlisting>
  111. <programlisting language="php"><![CDATA[
  112. /**
  113. [layout]
  114. layout = "foo"
  115. layoutPath = "/path/to/layouts"
  116. contentKey = "CONTENT"
  117. */
  118. $config = new Zend_Config_Ini('/path/to/layout.ini', 'layout');
  119. ]]></programlisting>
  120. <example id="zend.layout.options.examples.constructor">
  121. <title>オプションをコンストラクタあるいは startMvc() で渡す</title>
  122. <para>
  123. コンストラクタおよび静的メソッド <methodname>startMvc()</methodname>
  124. は、どちらもオプションの配列か
  125. <classname>Zend_Config</classname> オブジェクトを受け取ることができます。
  126. 受け取った内容をもとに
  127. <classname>Zend_Layout</classname> インスタンスの設定を行います。
  128. </para>
  129. <para>
  130. まず、配列を渡す方法を見てみましょう。
  131. </para>
  132. <programlisting language="php"><![CDATA[
  133. // コンストラクタを使用します
  134. $layout = new Zend_Layout($options);
  135. // startMvc() を使用します
  136. $layout = Zend_Layout::startMvc($options);
  137. ]]></programlisting>
  138. <para>
  139. 次に config オブジェクトを使用する方法です。
  140. </para>
  141. <programlisting language="php"><![CDATA[
  142. $config = new Zend_Config_Ini('/path/to/layout.ini', 'layout');
  143. // コンストラクタを使用します
  144. $layout = new Zend_Layout($config);
  145. // startMvc() を使用します
  146. $layout = Zend_Layout::startMvc($config);
  147. ]]></programlisting>
  148. <para>
  149. 基本的に、これは <classname>Zend_Layout</classname>
  150. インスタンスをカスタマイズするためのもっとも簡単な方法となります。
  151. </para>
  152. </example>
  153. <example id="zend.layout.options.examples.setoptionsconfig">
  154. <title>setOption() および setConfig() の使用</title>
  155. <para>
  156. 時には、インスタンスを作成した後で <classname>Zend_Layout</classname>
  157. を設定したくなることもあるでしょう。そんな場合は
  158. <methodname>setOptions()</methodname> や <methodname>setConfig()</methodname>
  159. を使用します。
  160. </para>
  161. <programlisting language="php"><![CDATA[
  162. // オプションの配列を使用します
  163. $layout->setOptions($options);
  164. // Zend_Config オブジェクトを使用します
  165. $layout->setConfig($options);
  166. ]]></programlisting>
  167. <para>
  168. しかし、ここで注意すべき点があります。
  169. <property>pluginClass</property> や <property>helperClass</property>
  170. のように、オプションによってはこのメソッドで指定しても無意味なものもあるのです。
  171. これらは、コンストラクタあるいは <methodname>startMvc()</methodname>
  172. メソッドで指定する必要があります。
  173. </para>
  174. </example>
  175. <example id="zend.layout.options.examples.accessors">
  176. <title>アクセサの使用</title>
  177. <para>
  178. 最後に、<classname>Zend_Layout</classname>
  179. のインスタンスをアクセサで設定することもできます。
  180. すべてのアクセサは流れるようなインターフェイスを実装しており、
  181. メソッドコールを連結して行えます。
  182. </para>
  183. <programlisting language="php"><![CDATA[
  184. $layout->setLayout('foo')
  185. ->setLayoutPath('/path/to/layouts')
  186. ->setContentKey('CONTENT');
  187. ]]></programlisting>
  188. </example>
  189. </sect2>
  190. </sect1>
  191. <!--
  192. vim:se ts=4 sw=4 et:
  193. -->