Zend_Layout-Advanced.xml 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect1 id="zend.layout.advanced">
  5. <title>Zend_Layout の高度な使用法</title>
  6. <para>
  7. <classname>Zend_Layout</classname> には、高度な使用法がいろいろあります。
  8. たとえばさまざまなビューの実装やファイルシステム上のレイアウトに対応させたりといったことです。
  9. </para>
  10. <para>
  11. 主な拡張ポイントは次のとおりです。
  12. </para>
  13. <itemizedlist>
  14. <listitem><para>
  15. <emphasis>ビューオブジェクトのカスタマイズ</emphasis>。
  16. <classname>Zend_Layout</classname> は、
  17. <classname>Zend_View_Interface</classname> を実装した任意のクラスを使用することができます。
  18. </para></listitem>
  19. <listitem><para>
  20. <emphasis>フロントコントローラプラグインのカスタマイズ</emphasis>。
  21. <classname>Zend_Layout</classname> に標準で含まれているフロントコントローラプラグインは、
  22. レイアウトを自動的にレンダリングしてからレスポンスを返します。
  23. これを独自のプラグインで置き換えることができます。
  24. </para></listitem>
  25. <listitem><para>
  26. <emphasis>アクションヘルパーのカスタマイズ</emphasis>。
  27. <classname>Zend_Layout</classname> に標準で含まれているアクションヘルパーは、
  28. ほとんどの場合にそのまま使えるでしょう。
  29. これは、レイアウトオブジェクト自信へのプロキシとなっています。
  30. </para></listitem>
  31. <listitem><para>
  32. <emphasis>レイアウトスクリプトのパス解決方法のカスタマイズ</emphasis>。
  33. <classname>Zend_Layout</classname> では、独自の <link
  34. linkend="zend.filter.inflector">インフレクタ</link>
  35. を使用してレイアウトスクリプトのパス解決方法を行うことができます。
  36. あるいは、標準のインフレクタを設定して独自のルールを指定することもできます。
  37. </para></listitem>
  38. </itemizedlist>
  39. <sect2 id="zend.layout.advanced.view">
  40. <title>ビューオブジェクトのカスタマイズ</title>
  41. <para>
  42. <classname>Zend_Layout</classname> では、
  43. <classname>Zend_View_Interface</classname> を実装した任意のクラスや
  44. <classname>Zend_View_Abstract</classname> を継承した任意のクラスを用いて
  45. レイアウトスクリプトをレンダリングすることができます。
  46. 独自のビューオブジェクトを単純に
  47. constructor/<code>startMvc()</code> のパラメータとして渡すか、
  48. あるいはアクセサ <code>setView()</code> で設定します。
  49. </para>
  50. <programlisting role="php"><![CDATA[
  51. $view = new My_Custom_View();
  52. $layout->setView($view);
  53. ]]>
  54. </programlisting>
  55. <note>
  56. <title>Zend_View の実装がすべて同じというわけではない</title>
  57. <para>
  58. <classname>Zend_Layout</classname> では
  59. <classname>Zend_View_Interface</classname> を実装した任意のクラスを使用できますが、
  60. その中で様々な <classname>Zend_View</classname> ヘルパー
  61. (特にレイアウトヘルパーや
  62. <link linkend="zend.view.helpers.initial.placeholder">プレースホルダ</link>
  63. ヘルパー)
  64. が使用できなければ問題となることもあるでしょう。
  65. これは、<classname>Zend_Layout</classname>
  66. がオブジェクトの中の変数を自分自身と
  67. <link linkend="zend.view.helpers.initial.placeholder">プレースホルダ</link>
  68. で使えるようにしているからです。
  69. </para>
  70. <para>
  71. これらのヘルパーをサポートしていない <classname>Zend_View</classname>
  72. の実装を使用する場合は、レイアウト変数をビューに取り込む方法を見つける必要があります。
  73. たとえば <classname>Zend_Layout</classname> オブジェクトを継承して
  74. <code>render()</code> メソッドにビューへの変数を渡すようにするか、
  75. あるいは独自のプラグインクラスを作成して
  76. レイアウトのレンダリングの前に変数を渡すようにするといった方法があります。
  77. </para>
  78. <para>
  79. あるいは、もしあなたの使用するビュー実装が何らかのプラグイン機構をサポートしているのなら、
  80. 'Zend_Layout' プレースホルダ経由で
  81. <link linkend="zend.view.helpers.initial.placeholder">
  82. プレースホルダヘルパー</link>
  83. を使用して変数にアクセスすることができます。
  84. </para>
  85. <programlisting role="php"><![CDATA[
  86. $placeholders = new Zend_View_Helper_Placeholder();
  87. $layoutVars = $placeholders->placeholder('Zend_Layout')->getArrayCopy();
  88. ]]>
  89. </programlisting>
  90. </note>
  91. </sect2>
  92. <sect2 id="zend.layout.advanced.plugin">
  93. <title>フロントコントローラプラグインのカスタマイズ</title>
  94. <para>
  95. MVC コンポーネントと組み合わせて使用するときに、
  96. <classname>Zend_Layout</classname> はフロントコントローラプラグインを登録します。
  97. このプラグインは、ディスパッチループを抜ける前の最後のアクションで
  98. レイアウトをレンダリングします。
  99. ほとんどの場合はデフォルトのプラグインで十分でしょうが、
  100. もし独自のプラグインを作成したい場合は、
  101. 作成したプラグインクラスの名前を
  102. <code>startMvc()</code> メソッドの
  103. <code>pluginClass</code> オプションで指定します。
  104. </para>
  105. <para>
  106. ここで使用するプラグインクラスは
  107. <classname>Zend_Controller_Plugin_Abstract</classname>
  108. を継承したものでなければなりません。また、コンストラクタの引数で
  109. レイアウトオブジェクトのインスタンスを受け取れるようにする必要があります。
  110. それ以外の実装内容については自由に決めることができます。
  111. </para>
  112. <para>
  113. デフォルトのプラグインは
  114. <classname>Zend_Layout_Controller_Plugin_Layout</classname>
  115. です。
  116. </para>
  117. </sect2>
  118. <sect2 id="zend.layout.advanced.helper">
  119. <title>アクションヘルパーのカスタマイズ</title>
  120. <para>
  121. MVC コンポーネントと組み合わせて使用するときに、
  122. <classname>Zend_Layout</classname> はアクションコントローラヘルパーを
  123. ヘルパーブローカに登録します。デフォルトのヘルパーである
  124. <classname>Zend_Layout_Controller_Action_Helper_Layout</classname>
  125. は、レイアウトオブジェクトのインスタンス自身に対する
  126. (何もしない) プロキシとしてはたらきます。
  127. たいていの場合はこれで十分でしょう。
  128. </para>
  129. <para>
  130. 独自の機能を書きたい場合は、
  131. <classname>Zend_Controller_Action_Helper_Abstract</classname>
  132. を継承したアクションヘルパークラスを作成します。
  133. そして、そのクラス名を
  134. <code>startMvc()</code> メソッドの
  135. <code>helperClass</code> オプションに指定します。
  136. 実装の詳細は自由に決められます。
  137. </para>
  138. </sect2>
  139. <sect2 id="zend.layout.advanced.inflector">
  140. <title>レイアウトスクリプトのパス解決方法のカスタマイズ: インフレクタの使用法</title>
  141. <para>
  142. <classname>Zend_Layout</classname> は、<classname>Zend_Filter_Inflector</classname>
  143. を使用して確立したフィルタチェインで
  144. レイアウト名からレイアウトスクリプトのパスへの変換を行います。
  145. デフォルトで使用するルールは、まず 'Word_CamelCaseToDash'、
  146. その後に 'StringToLower'、そして最後にサフィックス 'phtml'
  147. を追加してパスを作成します。たとえば次のようになります。
  148. </para>
  149. <itemizedlist>
  150. <listitem><para>
  151. 'foo' は 'foo.phtml' に変換されます。
  152. </para></listitem>
  153. <listitem><para>
  154. 'FooBarBaz' は 'foo-bar-baz.phtml' に変換されます。
  155. </para></listitem>
  156. </itemizedlist>
  157. <para>
  158. これを変更するには三通りの手段があります。
  159. インフレクションのターゲットやビューのサフィックスを
  160. <classname>Zend_Layout</classname> のアクセサで変更すること、
  161. <classname>Zend_Layout</classname> のインスタンスに関連づけられている
  162. インフレクタのルールを変更すること、
  163. あるいは独自のインフレクタのインスタンスを作成してそれを
  164. <classname>Zend_Layout::setInflector()</classname> で渡すことです。
  165. </para>
  166. <example id="zend.layout.advanced.inflector.accessors">
  167. <title>Zend_Layout のアクセサでインフレクタを変更する</title>
  168. <para>
  169. デフォルトの <classname>Zend_Layout</classname> のインフレクタは、
  170. ターゲットやビュースクリプトのサフィックスに静的な参照を用い、
  171. それらの値を設定するためのアクセサを提供しています。
  172. </para>
  173. <programlisting role="php"><![CDATA[
  174. // インフレクタのターゲットを設定します
  175. $layout->setInflectorTarget('layouts/:script.:suffix');
  176. // レイアウトビュースクリプトのサフィックスを設定します
  177. $layout->setViewSuffix('php');
  178. ]]>
  179. </programlisting>
  180. </example>
  181. <example id="zend.layout.advanced.inflector.directmodification">
  182. <title>Zend_Layout のインフレクタを直接変更する</title>
  183. <para>
  184. インフレクタは、ターゲットと (ひとつあるいは複数の)
  185. ルールを持っています。<classname>Zend_Layout</classname>
  186. が使用するデフォルトのターゲットは ':script.:suffix'
  187. です。':script' には登録されているレイアウト名、そして
  188. ':suffix' にはインフレクタの静的なルールが渡されます。
  189. </para>
  190. <para>
  191. たとえば、レイアウトスクリプトのサフィックスを
  192. 'html' に変更して、MixedCase および camelCase
  193. 形式の名前をダッシュではなくアンダースコアで区切るようにし、
  194. かつ小文字への変換もやめてみましょう。
  195. さらに、スクリプトの格納先を 'layouts'
  196. サブディレクトリに変更します。
  197. </para>
  198. <programlisting role="php"><![CDATA[
  199. $layout->getInflector()->setTarget('layouts/:script.:suffix')
  200. ->setStaticRule('suffix', 'html')
  201. ->setFilterRule(array('Word_CamelCaseToUnderscore'));
  202. ]]>
  203. </programlisting>
  204. </example>
  205. <example id="zend.layout.advanced.inflector.custom">
  206. <title>インフレクタのカスタマイズ</title>
  207. <para>
  208. ほとんどの場合は、既存のインフレクタを修正するだけで十分でしょう。
  209. しかし、さまざまな場所で別の形式のオブジェクトを使い分けたいこともあります。
  210. <classname>Zend_Layout</classname> はそんな場合にも対応しています。
  211. </para>
  212. <programlisting role="php"><![CDATA[
  213. $inflector = new Zend_Filter_Inflector('layouts/:script.:suffix');
  214. $inflector->addRules(array(
  215. ':script' => array('Word_CamelCaseToUnderscore'),
  216. 'suffix' => 'html'
  217. ));
  218. $layout->setInflector($inflector);
  219. ]]>
  220. </programlisting>
  221. </example>
  222. <note>
  223. <title>インフレクションを無効にできます</title>
  224. <para>
  225. インフレクションを無効にしたり有効にしたりするには、
  226. <classname>Zend_Layout</classname> オブジェクトのアクセサを使用します。
  227. これは、たとえばレイアウトビュースクリプトを絶対パスで指定したい場合などに便利です。
  228. また、レイアウトスクリプトを指定するためのインフレクションが特に不要な場合にも便利です。
  229. 有効にしたり無効にしたりするには、単純に <code>enableInflection()</code> メソッドおよび
  230. <code>disableInflection()</code> メソッドを使用します。
  231. </para>
  232. </note>
  233. </sect2>
  234. </sect1>
  235. <!--
  236. vim:se ts=4 sw=4 et:
  237. -->