Zend_Controller-ActionHelpers-ActionStack.xml 4.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24249 -->
  4. <sect3 id="zend.controller.actionhelpers.actionstack">
  5. <title>ActionStack(日本語)</title>
  6. <para>
  7. <emphasis>ActionStack</emphasis> ヘルパーは、リクエストをフロントコントローラの
  8. <link linkend="zend.controller.plugins.standard.actionstack">ActionStack</link>
  9. プラグインに格納します。これにより、
  10. リクエストの実行時にアクションのキューを作成しやすくなります。
  11. このヘルパーは、アクションを追加する際に
  12. 新しいリクエストオブジェクトを指定するか
  13. アクション - コントローラ - モジュール の設定を指定するかのいずれかを用います。
  14. </para>
  15. <note>
  16. <title>ActionStack ヘルパーを起動すると ActionStack プラグインが初期化される</title>
  17. <para>
  18. <emphasis>ActionStack</emphasis> を起動すると、暗黙のうちに
  19. <emphasis>ActionStack</emphasis> プラグインを登録します。
  20. つまり、この機能を使う際に明示的に <emphasis>ActionStack</emphasis>
  21. プラグインを登録する必要はないということです。
  22. </para>
  23. </note>
  24. <example id="zend.controller.actionhelpers.actionstack.simple">
  25. <title>アクション、コントローラおよびモジュール名によるタスクの追加</title>
  26. <para>
  27. 単純にアクションとコントローラそしてモジュール
  28. (およびオプションでリクエストパラメータ)
  29. を指定して <methodname>Zend_Controller_Action::_forward()</methodname>
  30. をコールするのが一番シンプルな方法です。
  31. </para>
  32. <programlisting language="php"><![CDATA[
  33. class FooController extends Zend_Controller_Action
  34. {
  35. public function barAction()
  36. {
  37. // 2 つのアクションをスタックに格納して
  38. // /foo/baz/bar/baz をコールします
  39. // (FooController::bazAction() にリクエスト変数 bar == baz を指定したもの)
  40. $this->_helper->actionStack('baz',
  41. 'foo',
  42. 'default',
  43. array('bar' => 'baz'));
  44. // /bar/bat のコール
  45. // (BarController::batAction()) を追加します
  46. $this->_helper->actionStack('bat', 'bar');
  47. }
  48. }
  49. ]]></programlisting>
  50. </example>
  51. <example id="zend.controller.actionhelpers.actionstack.simple2">
  52. <title>リクエストオブジェクトによるタスクの追加</title>
  53. <para>
  54. 時にはリクエストオブジェクトのオブジェクト指向的な部分が使いたいこともあるでしょう。
  55. そんな場合はこのオブジェクトを <emphasis>ActionStack</emphasis>
  56. ヘルパーに渡すこともできます。
  57. </para>
  58. <programlisting language="php"><![CDATA[
  59. class FooController extends Zend_Controller_Action
  60. {
  61. public function barAction()
  62. {
  63. // 2 つのアクションをスタックに格納して
  64. // /foo/baz/bar/baz をコールします
  65. // (FooController::bazAction() にリクエスト変数 bar == baz を指定したもの)
  66. $request = clone $this->getRequest();
  67. // コントローラやモジュールは指定せず、現在の値を使用します
  68. $request->setActionName('baz')
  69. ->setParams(array('bar' => 'baz'));
  70. $this->_helper->actionStack($request);
  71. // /bar/bat のコール
  72. // (BarController::batAction()) を追加します
  73. $request = clone $this->getRequest();
  74. // モジュールは指定せず、現在の値を使用します
  75. $request->setActionName('bat')
  76. ->setControllerName('bar');
  77. $this->_helper->actionStack($request);
  78. }
  79. }
  80. ]]></programlisting>
  81. </example>
  82. </sect3>
  83. <!--
  84. vim:se ts=4 sw=4 et:
  85. -->