Zend_Controller-ActionHelpers-ActionStack.xml 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 15103 -->
  4. <sect3 id="zend.controller.actionhelpers.actionstack">
  5. <title>ActionStack</title>
  6. <para>
  7. <code>ActionStack</code> ヘルパーは、リクエストをフロントコントローラの
  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. <code>ActionStack</code> を起動すると、暗黙のうちに
  19. <code>ActionStack</code> プラグインを登録します。
  20. つまり、この機能を使う際に明示的に <code>ActionStack</code>
  21. プラグインを登録する必要はないということです。
  22. </para>
  23. </note>
  24. <example id="zend.controller.actionhelpers.actionstack.simple">
  25. <title>アクション、コントローラおよびモジュール名によるタスクの追加</title>
  26. <para>
  27. 単純にアクションとコントローラそしてモジュール
  28. (およびオプションでリクエストパラメータ)
  29. を指定して <classname>Zend_Controller_Action::_forward()</classname>
  30. をコールするのが一番シンプルな方法です。
  31. </para>
  32. <programlisting role="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. ]]>
  50. </programlisting>
  51. </example>
  52. <example id="zend.controller.actionhelpers.actionstack.simple2">
  53. <title>リクエストオブジェクトによるタスクの追加</title>
  54. <para>
  55. 時にはリクエストオブジェクトのオブジェクト指向的な部分が使いたいこともあるでしょう。
  56. そんな場合はこのオブジェクトを <code>ActionStack</code>
  57. ヘルパーに渡すこともできます。
  58. </para>
  59. <programlisting role="php"><![CDATA[
  60. class FooController extends Zend_Controller_Action
  61. {
  62. public function barAction()
  63. {
  64. // 2 つのアクションをスタックに格納して
  65. // /foo/baz/bar/baz をコールします
  66. // (FooController::bazAction() にリクエスト変数 bar == baz を指定したもの)
  67. $request = clone $this->getRequest();
  68. // コントローラやモジュールは指定せず、現在の値を使用します
  69. $request->setActionName('baz')
  70. ->setParams(array('bar' => 'baz'));
  71. $this->_helper->actionStack($request);
  72. // /bar/bat のコール
  73. // (BarController::batAction()) を追加します
  74. $request = clone $this->getRequest();
  75. // モジュールは指定せず、現在の値を使用します
  76. $request->setActionName('bat')
  77. ->setControllerName('bar');
  78. $this->_helper->actionStack($request);
  79. }
  80. }
  81. ]]>
  82. </programlisting>
  83. </example>
  84. </sect3>
  85. <!--
  86. vim:se ts=4 sw=4 et:
  87. -->