Zend_Controller-ActionHelpers-ActionStack.xml 4.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.controller.actionhelpers.actionstack">
  5. <title>ActionStack</title>
  6. <para>
  7. Помощник <emphasis>ActionStack</emphasis> позволяет добавлять в стек запросы к плагину
  8. фронт-контроллера, именуемуму
  9. <link linkend="zend.controller.plugins.standard.actionstack">ActionStack</link>.
  10. Это позволяет создать очередь из задач, планируемых к выполнению в ходе данного запроса.
  11. Помощник <emphasis>ActionStack</emphasis> позволяет добавлять задачи как путем указания
  12. новых объектов запроса, так и набора действие - контроллер - модуль.
  13. </para>
  14. <note>
  15. <title>Вызов помощника ActionStack инициализирует плагин ActionStack</title>
  16. <para>
  17. Вызов помощника <emphasis>ActionStack</emphasis> неявно регистрирует плагин
  18. <emphasis>ActionStack</emphasis>, следовательно, нет необходимости
  19. явным образом регистрировать плагин <emphasis>ActionStack</emphasis>
  20. для использования данной функциональности.
  21. </para>
  22. </note>
  23. <example id="zend.controller.actionhelpers.actionstack.simple">
  24. <title>Добавление задачи с указанием имен действия, контроллера и модуля</title>
  25. <para>
  26. Зачастую, проще всего указать имена действия, контроллера и модуля
  27. (и прочие параметры запроса) таким же образом, как и при вызове
  28. <methodname>Zend_Controller_Action::_forward()</methodname>:
  29. </para>
  30. <programlisting language="php"><![CDATA[
  31. class FooController extends Zend_Controller_Action
  32. {
  33. public function barAction()
  34. {
  35. // Добавить две задачи в стек
  36. // Добавить вызов к /foo/baz/bar/baz
  37. // (FooController::bazAction() со следующими переменными в запросе: bar = baz)
  38. $this->_helper->actionStack('baz',
  39. 'foo',
  40. 'default',
  41. array('bar' => 'baz'));
  42. // Добавить вызов к /bar/bat
  43. // (BarController::batAction())
  44. $this->_helper->actionStack('bat', 'bar');
  45. }
  46. }
  47. ]]></programlisting>
  48. </example>
  49. <example id="zend.controller.actionhelpers.actionstack.simple2">
  50. <title>Добавление задачи с использованием нового объекта запроса</title>
  51. <para>
  52. Иногда появляется необходимость работать с запросом как с объектом
  53. (в лучших традициях <acronym>ООП</acronym>). В таком случае объект запроса
  54. можно передать помощнику <emphasis>ActionStack</emphasis> при его вызове.
  55. </para>
  56. <programlisting language="php"><![CDATA[
  57. class FooController extends Zend_Controller_Action
  58. {
  59. public function barAction()
  60. {
  61. // Добавить две задачи в стек
  62. // Добавить вызов к /foo/baz/bar/baz
  63. // (FooController::bazAction() со следующими
  64. // переменными в запросе: bar = baz)
  65. $request = clone $this->getRequest();
  66. // Использовать текущие контроллер и модуль;
  67. // установить новое действие - baz
  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. // Использовать текущий модуль; установить новый контроллер - bar
  75. // и действие - bat
  76. $request->setActionName('bat')
  77. ->setControllerName('bar');
  78. $this->_helper->actionStack($request);
  79. }
  80. }
  81. ]]></programlisting>
  82. </example>
  83. </sect3>
  84. <!--
  85. vim:se ts=4 sw=4 et:
  86. -->