Zend_Controller-ActionHelpers.xml 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.controller.actionhelpers" xmlns:xi="http://www.w3.org/2001/XInclude">
  5. <title>Aides d'action (Helper)</title>
  6. <sect2 id="zend.controller.actionhelper.introduction">
  7. <title>Introduction</title>
  8. <para>
  9. Les aides d'action permettent aux développeurs d'injecter, en cours d'exécution
  10. et&#160;/&#160;ou à la demande, des fonctionnalités dans tout contrôleur d'action qui
  11. étend <classname>Zend_Controller_Action</classname>. Le but des aides d'action est de
  12. minimiser la nécessité d'étendre le contrôleur d'action abstrait en y injectant des
  13. fonctionnalités communes de contrôleur d'action.
  14. </para>
  15. <para>
  16. Il y a de nombreuses manières d'utiliser les aides d'action. Les aides d'action
  17. utilisent le système de gestionnaire ("Broker"), similaire aux gestionnaires vus pour
  18. les <link linkend="zend.view.helpers">Zend_View_Helper</link>, et les
  19. <link linkend="zend.controller.plugins">Zend_Controller_Plugin</link>. Les aides
  20. d'action (comme les aides de vue <classname>Zend_View_Helper</classname>) peuvent être
  21. chargées et appelées à la demande, ou elles peuvent être instanciées au début de la
  22. requête ("bootstrap") ou au moment de la création des contrôleurs d'action
  23. (<methodname>init()</methodname>). Pour mieux comprendre ceci, reportez vous à la
  24. section d'utilisation ci-dessous.
  25. </para>
  26. </sect2>
  27. <sect2 id="zend.controller.actionhelper.initialization">
  28. <title>Initialisation des aides</title>
  29. <para>
  30. Une aide peut être initialisée de plusieurs manières différentes, basées sur vos
  31. besoins aussi bien que la fonctionnalité de l'aide.
  32. </para>
  33. <para>
  34. Le gestionnaire d'aide est stocké en tant que membre <varname>$_helper</varname> du
  35. <classname>Zend_Controller_Action</classname> ; utilisez le gestionnaire pour récupérer
  36. ou appeler les aides. Les méthodes pour faire ceci incluent&#160;:
  37. </para>
  38. <itemizedlist>
  39. <listitem>
  40. <para>
  41. L'utilisation explicite de <methodname>getHelper()</methodname>. Passez lui
  42. simplement un nom, et l'objet d'aide est retourné&#160;:
  43. </para>
  44. <programlisting language="php"><![CDATA[
  45. $flashMessenger = $this->_helper->getHelper('FlashMessenger');
  46. $message = 'Nous avons fait quelquechose lors de la dernière requête';
  47. $flashMessenger->addMessage($message);
  48. ]]></programlisting>
  49. </listitem>
  50. <listitem>
  51. <para>
  52. L'utilisation de la fonctionnalité <methodname>__get()</methodname> du
  53. gestionnaire d'aide et récupérez l'aide comme si elle était une propriété
  54. membre du gestionnaire&#160;:
  55. </para>
  56. <programlisting language="php"><![CDATA[
  57. $flashMessenger = $this->_helper->FlashMessenger;
  58. $message = 'Nous avons fait quelquechose lors de la dernière requête';
  59. $flashMessenger->addMessage($message);
  60. ]]></programlisting>
  61. </listitem>
  62. <listitem>
  63. <para>
  64. Enfin, la plupart des aides d'action implémente la méthode
  65. <methodname>direct()</methodname> qui va appeler une méthode spécifique
  66. par défaut dans l'aide. Dans l'exemple de <emphasis>FlashMessenger</emphasis>,
  67. ceci appelle <methodname>addMessage()</methodname>&#160;:
  68. </para>
  69. <programlisting language="php"><![CDATA[
  70. $message = 'Nous avons fait quelquechose lors de la dernière requête';
  71. $this->_helper->FlashMessenger($message);
  72. ]]></programlisting>
  73. </listitem>
  74. </itemizedlist>
  75. <note>
  76. <para>Tous les exemples ci-dessus sont équivalents.</para>
  77. </note>
  78. <para>
  79. Vous pouvez vouloir aussi instancier les aides explicitement. Vous pourriez avoir
  80. besoin de ceci si vous utilisez l'aide hors du contexte du contrôleur d'action, ou si
  81. vous souhaitez fournir une aide au gestionnaire d'aides à utiliser pour une action
  82. quelconque. L'instanciation se fait comme toute autre classe <acronym>PHP</acronym>.
  83. </para>
  84. </sect2>
  85. <sect2 id="zend.controller.actionhelper.broker">
  86. <title>Le gestionnaire d'aide (Broker)</title>
  87. <para>
  88. <classname>Zend_Controller_Action_HelperBroker</classname> gère les détails de
  89. l'enregistrement des objets d'aide et les chemins de ces aides, ainsi que la
  90. récupération des aides à la demande.
  91. </para>
  92. <para>
  93. Pour enregistrer une aide dans le gestionnaire, utilisez
  94. <methodname>addHelper()</methodname>&#160;:
  95. </para>
  96. <programlisting language="php"><![CDATA[
  97. Zend_Controller_Action_HelperBroker::addHelper($helper);
  98. ]]></programlisting>
  99. <para>
  100. Bien sûr, instancier et fournir des aides au gestionnaire est coûteux en temps et
  101. en ressource donc deux méthodes existent pour automatiser les choses légèrement&#160;:
  102. <methodname>addPrefix()</methodname> et <methodname>addPath()</methodname>.
  103. </para>
  104. <itemizedlist>
  105. <listitem>
  106. <para>
  107. <methodname>addPrefix()</methodname> prend un préfixe de classe et l'utilise
  108. pour déterminer le chemin des dossiers dans lesquels les classes d'aides ont
  109. été définies. Ceci suppose que le préfixe de la classe respecte la convention
  110. de nommage de Zend Framework.
  111. </para>
  112. <programlisting language="php"><![CDATA[
  113. // Ajoute les aides préfixées Mes_Action_Helpers dans Mes/Action/Helpers/
  114. Zend_Controller_Action_HelperBroker::addPrefix('Mes_Action_Helpers');
  115. ]]></programlisting>
  116. </listitem>
  117. <listitem>
  118. <para>
  119. <methodname>addPath()</methodname> prend un répertoire en premier argument et
  120. un préfixe de classe en second (par défaut réglé à
  121. "<classname>Zend_Controller_Action_Helper</classname>"). Ceci vous permet de
  122. faire correspondre vos propres préfixes de classe à vos dossiers spécifiques.
  123. </para>
  124. <programlisting language="php"><![CDATA[
  125. // Ajoute les aides préfixées avec Aide dans Plugins/Aides/
  126. Zend_Controller_Action_HelperBroker::addPath('./Plugins/Aides', 'Aide');
  127. ]]></programlisting>
  128. </listitem>
  129. </itemizedlist>
  130. <para>
  131. Puisque ces méthodes sont statiques, elles peuvent être appelées en tout point du
  132. déroulement du contrôleur pour ajouter dynamiquement les aides nécessaires.
  133. </para>
  134. <para>
  135. En interne, le gestionnaire d'aide utilise
  136. <link linkend="zend.loader.pluginloader">une instance de PluginLoader</link>pour
  137. conserver les chemins. Vous pouvez récupérer le PluginLoader en utilisant la méthode
  138. statique <methodname>getPluginLoader()</methodname>, ou alternativement, injecter une
  139. instance personnalisée de PluginLoader en utilisant
  140. <methodname>setPluginLoader()</methodname>.
  141. </para>
  142. <para>
  143. Pour déterminer si une aide existe dans le gestionnaire d'aide, utilisez
  144. <methodname>hasHelper($name)</methodname>, où <varname>$name</varname> est
  145. le nom raccourci de l'aide (sans le préfixe)&#160;:
  146. </para>
  147. <programlisting language="php"><![CDATA[
  148. // Vérifie si l'aide 'redirector' est enregistrée dans le gestionnaire :
  149. if (Zend_Controller_Action_HelperBroker::hasHelper('redirector')) {
  150. echo 'L\'aide Redirector est enregistrée';
  151. }
  152. ]]></programlisting>
  153. <para>
  154. Il existe aussi deux méthodes statiques pour récupérer les aides issues du
  155. gestionnaire d'aide : <methodname>getExistingHelper()</methodname> et
  156. <methodname>getStaticHelper()</methodname>.
  157. <methodname>getExistingHelper()</methodname> récupérera une aide seulement si elle
  158. a précédemment été invoquée par ou explicitement enregistrée dans le
  159. gestionnaire d'aides; la méthode lèvera une exception sinon.
  160. <methodname>getStaticHelper()</methodname> réalise la même chose que
  161. <methodname>getExistingHelper()</methodname>, mais tentera d'instancier l'aide si elle
  162. n'a pas déjà été enregistrée dans la pile des aides.
  163. <methodname>getStaticHelper()</methodname> est un bon choix pour récupérer les aides
  164. que vous voulez configurer.
  165. </para>
  166. <para>
  167. Les deux méthodes prennent un unique paramètre, <varname>$name</varname>, qui est le
  168. nom court de l'aide (c'est-à-dire sans le préfixe).
  169. </para>
  170. <programlisting language="php"><![CDATA[
  171. // Vérifie si l'aide 'redirector' est enregistrée dans le gestionnaire,
  172. // et l'extrait :
  173. if (Zend_Controller_Action_HelperBroker::hasHelper('redirector')) {
  174. $redirector =
  175. Zend_Controller_Action_HelperBroker::getExistingHelper('redirector');
  176. }
  177. // Ou, simplement le récupère, sans se soucier s'il a ou non été
  178. // enregistré précédemment :
  179. $redirector =
  180. Zend_Controller_Action_HelperBroker::getStaticHelper('redirector');
  181. }
  182. ]]></programlisting>
  183. <para>
  184. Enfin, pour effacer une aide enregistrée du gestionnaire, utilisez
  185. <methodname>removeHelper($name)</methodname>, où <varname>$name</varname>
  186. est le nom raccourci de l'aide (sans le préfixe)&#160;:
  187. </para>
  188. <programlisting language="php"><![CDATA[
  189. // Effacement conditionnel de l'aide 'redirector' du gestionnaire :
  190. if (Zend_Controller_Action_HelperBroker::hasHelper('redirector')) {
  191. Zend_Controller_Action_HelperBroker::removeHelper('redirector')
  192. }
  193. ]]></programlisting>
  194. </sect2>
  195. <sect2 id="zend.controller.actionhelper.stockhelpers">
  196. <title>Aides d'action intégrées</title>
  197. <para>
  198. Zend Framework inclue plusieurs aides d'action par défaut&#160;:
  199. <emphasis>AutoComplete</emphasis> pour des réponses automatiques à des auto-complétions
  200. <acronym>AJAX</acronym>&#160;; <emphasis>ContextSwitch</emphasis> et
  201. <emphasis>AjaxContext</emphasis> pour distribuer des formats de réponse alternatifs
  202. pour vos actions ; <emphasis>FlashMessenger</emphasis> pour gérer des
  203. messages entre les sessions ; <emphasis>Json</emphasis> pour encoder et envoyer des
  204. réponses <acronym>JSON</acronym>&#160;; <emphasis>Redirector</emphasis>, qui fournit
  205. différentes implémentations pour rediriger vers des pages internes ou externes à votre
  206. application&#160;; et <emphasis>ViewRenderer</emphasis> pour automatiser le processus
  207. de paramétrage de vos objets de vues dans votre contrôleur et du rendu de ces vues.
  208. </para>
  209. <xi:include href="Zend_Controller-ActionHelpers-ActionStack.xml" />
  210. <xi:include href="Zend_Controller-ActionHelpers-AutoComplete.xml" />
  211. <xi:include href="Zend_Controller-ActionHelpers-ContextSwitch.xml" />
  212. <xi:include href="Zend_Controller-ActionHelpers-FlashMessenger.xml" />
  213. <xi:include href="Zend_Controller-ActionHelpers-Json.xml" />
  214. <xi:include href="Zend_Controller-ActionHelpers-Redirector.xml" />
  215. <xi:include href="Zend_Controller-ActionHelpers-ViewRenderer.xml" />
  216. </sect2>
  217. <sect2 id="zend.controller.actionhelper.writingyourown">
  218. <title>Écrire vos propres aides</title>
  219. <para>
  220. Les aides d'action étendent
  221. <classname>Zend_Controller_Action_Helper_Abstract</classname>, une classe abstraite qui
  222. fournit l'interface basique et les fonctionnalités requises par le gestionnaire
  223. d'aides. Ceci inclue les méthodes suivantes&#160;:
  224. </para>
  225. <itemizedlist>
  226. <listitem>
  227. <para>
  228. <methodname>setActionController()</methodname> est utilisée pour paramétrer le
  229. contrôleur d'action courant.
  230. </para>
  231. </listitem>
  232. <listitem>
  233. <para>
  234. <methodname>init()</methodname>, déclenchée par le gestionnaire d'aides à
  235. l'instanciation, peut être utilisée pour déclencher l'initialisation dans
  236. l'aide&#160;; ceci peut être pratique pour remettre dans l'état initial quand
  237. de multiples contrôleurs utilisent la même aide dans des actions enchaînées.
  238. </para>
  239. </listitem>
  240. <listitem>
  241. <para>
  242. <methodname>preDispatch()</methodname> est déclenchée avant la distribution
  243. d'une action.
  244. </para>
  245. </listitem>
  246. <listitem>
  247. <para>
  248. <methodname>postDispatch()</methodname> est déclenchée quand une action a été
  249. distribuée - même si un plugin <methodname>preDispatch()</methodname> a évité
  250. l'action. Principalement utile pour le nettoyage.
  251. </para>
  252. </listitem>
  253. <listitem>
  254. <para>
  255. <methodname>getRequest()</methodname> récupère l'objet de requête courant.
  256. </para>
  257. </listitem>
  258. <listitem>
  259. <para>
  260. <methodname>getResponse()</methodname> récupère l'objet de réponse courant.
  261. </para>
  262. </listitem>
  263. <listitem>
  264. <para>
  265. <methodname>getName()</methodname> récupère le nom de l'aide. Elle récupère la
  266. portion du nom de la classe qui suit le dernier tiret bas ("_"), ou le nom de
  267. la classe entier sinon. Pour exemple, si la classe est nommée
  268. <classname>Zend_Controller_Action_Helper_Redirector</classname>, elle retourne
  269. <emphasis>Redirector</emphasis>&#160;; une classe nommée
  270. <emphasis>FooMessage</emphasis> retournera elle-même.
  271. </para>
  272. </listitem>
  273. </itemizedlist>
  274. <para>
  275. Vous pouvez optionnellement inclure une méthode <methodname>direct()</methodname> dans
  276. votre classe d'aide. Si définie, ceci vous permet de traiter l'aide comme une méthode du
  277. gestionnaire, dans le but de faciliter un usage unique de l'aide. Pour exemple, l'aide
  278. <link linkend="zend.controller.actionhelpers.redirector">Redirector</link>définit
  279. <methodname>direct()</methodname> comme un alias de <methodname>goto()</methodname>,
  280. vous permettant d'utiliser l'aide comme ceci&#160;:
  281. </para>
  282. <programlisting language="php"><![CDATA[
  283. // Redirige vers /blog/view/item/id/42
  284. $this->_helper->redirector('item', 'view', 'blog', array('id' => 42));
  285. ]]></programlisting>
  286. <para>
  287. En interne, la méthode <methodname>__call()</methodname> du gestionnaire d'aides
  288. cherche une aide nommée <emphasis>redirector</emphasis>, puis vérifie si cette aide
  289. possède une méthode <methodname>direct()</methodname>, et enfin appelle cette méthode
  290. avec les arguments fournis.
  291. </para>
  292. <para>
  293. Une fois que vous avez créé vos propres classes d'aide, vous pouvez en fournir
  294. l'accès comme décrit dans les sections ci-dessus.
  295. </para>
  296. </sect2>
  297. </sect1>