Zend_Controller-ActionHelpers-ContextSwitch.xml 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 20765 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.controller.actionhelpers.contextswitch">
  5. <title>ContextSwitch et AjaxContext</title>
  6. <para>
  7. L'aide d'action <emphasis>ContextSwitch</emphasis> est destinée à faciliter le retour de
  8. différents formats de réponse à une requête.L'<emphasis>AjaxContext</emphasis> est une aide
  9. spécialisée de <emphasis>ContextSwitch</emphasis> qui permet le renvoi de réponses à
  10. XmlHttpRequest.
  11. </para>
  12. <para>
  13. Pour l'activer, vous devez indiquer à votre contrôleur quelles actions répondent à
  14. quel contexte. Si une requête d'entrée indique un contexte valide pour une action, alors
  15. l'aide d'action en charge&#160;:
  16. </para>
  17. <itemizedlist>
  18. <listitem>
  19. <para>
  20. Va désactiver les layouts, si elles sont activées.
  21. </para>
  22. </listitem>
  23. <listitem>
  24. <para>
  25. Va changer le suffixe de la vue à rendre, il faudra donc créer une vue par
  26. contexte.
  27. </para>
  28. </listitem>
  29. <listitem>
  30. <para>
  31. Va envoyer les bons en-têtes de réponse en fonction du contexte désiré.
  32. </para>
  33. </listitem>
  34. <listitem>
  35. <para>
  36. Va éventuellement en option appeler des fonctions pour configurer le
  37. contexte, ou des fonctions de post-processing.
  38. </para>
  39. </listitem>
  40. </itemizedlist>
  41. <para>Comme exemple, prenons le contrôleur suivant&#160;:</para>
  42. <programlisting language="php"><![CDATA[
  43. class NewsController extends Zend_Controller_Action
  44. {
  45. /**
  46. * page d'arrivée; forward vers listAction()
  47. */
  48. public function indexAction()
  49. {
  50. $this->_forward('list');
  51. }
  52. /**
  53. * Liste les news
  54. */
  55. public function listAction()
  56. {
  57. }
  58. /**
  59. * Affiche une new particulière
  60. */
  61. public function viewAction()
  62. {
  63. }
  64. }
  65. ]]></programlisting>
  66. <para>
  67. Imaginons que nous voulions que <methodname>listAction()</methodname> soit aussi accessible
  68. au format <acronym>XML</acronym>. Plutôt que de créer une autre action, nous pouvons lui
  69. indiquer qu'elle doit retourner du <acronym>XML</acronym>&#160;:
  70. </para>
  71. <programlisting language="php"><![CDATA[
  72. class NewsController extends Zend_Controller_Action
  73. {
  74. public function init()
  75. {
  76. $contextSwitch = $this->_helper->getHelper('contextSwitch');
  77. $contextSwitch->addActionContext('list', 'xml')
  78. ->initContext();
  79. }
  80. // ...
  81. }
  82. ]]></programlisting>
  83. <para>Ce code aura pour effet&#160;:</para>
  84. <itemizedlist>
  85. <listitem>
  86. <para>
  87. De changer le "Content-Type" de la réponse en "<filename>text/xml</filename>".
  88. </para>
  89. </listitem>
  90. <listitem>
  91. <para>
  92. De changer le suffixe de vue vers "<filename>xml.phtml</filename>" (ou un autre
  93. suffixe si vous en utilisez un personnalisé "xml.[votre suffixe]").
  94. </para>
  95. </listitem>
  96. </itemizedlist>
  97. <para>
  98. Il est donc nécessaire de créer un nouveau script de vue,
  99. "<filename>news/list.xml.phtml</filename>", qui créera et rendra le
  100. <acronym>XML</acronym>.
  101. </para>
  102. <para>
  103. Pour savoir si la requête doit utiliser un contexte switch, l'aide vérifie un jeton
  104. dans l'objet de requête. Par défaut, l'aide va chercher le paramètre de requête "format",
  105. ceci peut être changé. Ceci signifie que dans la plupart des cas, pour changer le contexte
  106. d'une réponse, il faut simplement injecter un paramètre "format" à la requête:
  107. </para>
  108. <itemizedlist>
  109. <listitem>
  110. <para>
  111. Via l'<acronym>URL</acronym>&#160;: <filename>/news/list/format/xml</filename>
  112. (le routeur par défaut utilise les paires clés et valeurs fournies après l'action)
  113. </para>
  114. </listitem>
  115. <listitem>
  116. <para>
  117. Via un paramètre <constant>GET</constant>&#160;:
  118. <command>/news/list?format=xml</command>
  119. </para>
  120. </listitem>
  121. </itemizedlist>
  122. <para>
  123. <emphasis>ContextSwitch</emphasis> vous permet d'écrire des contextes, ceux-ci spécifient le
  124. suffixe de vue qui change, les en-têtes de réponse à modifier, et les fonctions de
  125. rappel éventuelles.
  126. </para>
  127. <sect4 id="zend.controller.actionhelpers.contextswitch.contexts">
  128. <title>Contextes inclus par défaut</title>
  129. <para>
  130. Par défaut, il existe 2 contextes dans l'aide <emphasis>ContextSwitch</emphasis>&#160;:
  131. json et xml.
  132. </para>
  133. <itemizedlist>
  134. <listitem>
  135. <para>
  136. <emphasis><acronym>JSON</acronym></emphasis>. Le contexte
  137. <acronym>JSON</acronym> met le "Content-Type" de la réponse à
  138. "<filename>application/json</filename>", et le suffixe de la vue est
  139. "<filename>json.phtml</filename>".
  140. </para>
  141. <para>
  142. Par défaut cependant, aucun script de vue n'est nécessaire, il va simplement
  143. sérialiser en <acronym>JSON</acronym> toutes les variables de vues, et les
  144. envoyer en tant que réponse.
  145. </para>
  146. <para>
  147. Ce comportement peut être désactivé en éteigant le paramètre de
  148. sérialisation <acronym>JSON</acronym>&#160;:
  149. </para>
  150. <programlisting language="php"><![CDATA[
  151. $this->_helper->contextSwitch()->setAutoJsonSerialization(false);
  152. ]]></programlisting>
  153. </listitem>
  154. <listitem>
  155. <para>
  156. <emphasis><acronym>XML</acronym></emphasis>. Le contexte <acronym>XML</acronym>
  157. met le "Content-Type" de la réponse à "<filename>text/xml</filename>", et
  158. utilise un suffixe de vue "<filename>xml.phtml</filename>". Vous devrez
  159. créer une nouvelle vue pour ce contexte.
  160. </para>
  161. </listitem>
  162. </itemizedlist>
  163. </sect4>
  164. <sect4 id="zend.controller.actionhelpers.contextswitch.custom">
  165. <title>Créer ses propres contextes</title>
  166. <para>
  167. Vous pouvez créer vos propres contextes d'action. Par exemple pour retourner du
  168. <acronym>YAML</acronym>, du <acronym>PHP</acronym> sérialisé, ou encore du
  169. <acronym>RSS</acronym> ou du <acronym>ATOM</acronym>. <emphasis>ContextSwitch</emphasis>
  170. est là pour cela.
  171. </para>
  172. <para>
  173. La manière la plus simple d'ajouter un nouveau contexte d'action est la méthode
  174. <methodname>addContext()</methodname>. Elle prend 2 paramètres : le nom du contexte,
  175. et un tableau d'options. Ce tableau d'option doit comporter au moins une des clés
  176. suivantes&#160;:
  177. </para>
  178. <itemizedlist>
  179. <listitem>
  180. <para>
  181. <emphasis>suffix</emphasis>&#160;: Le préfixe qui va s'ajouter au suffixe de
  182. vue. Il sera utiliser par le ViewRenderer.
  183. </para>
  184. </listitem>
  185. <listitem>
  186. <para>
  187. <emphasis>headers</emphasis>&#160;: un tableau d'en-têtes et de valeurs que
  188. vous voulez ajouter à la réponse.
  189. </para>
  190. </listitem>
  191. <listitem>
  192. <para>
  193. <emphasis>callbacks</emphasis>&#160;: un tableau dont les clés peuvent être
  194. "init" ou "post", et les valeurs représentent des noms de fonctions
  195. <acronym>PHP</acronym> valides, qui seront utilisées pour initialiser ou
  196. traiter la fin du contexte.
  197. </para>
  198. <para>
  199. Les fonctions d'initialisation interviennent lorsque le contexte est détecté
  200. par <emphasis>ContextSwitch</emphasis>. Par exemple dans le contexte intégré
  201. <acronym>JSON</acronym>, la fonction désactive le ViewRenderer lorsque la
  202. sérialisation automatique <acronym>JSON</acronym> est activée.
  203. </para>
  204. <para>
  205. Les fonctions de traitement de fin de contexte (Post processing) interviennent
  206. durant le processus de <methodname>postDispatch()</methodname> de l'action en
  207. cours. Par exemple pour le contexte intégré <acronym>JSON</acronym>, la
  208. fonction de post process regarde si la sérialisation automatique
  209. <acronym>JSON</acronym> est active, si c'est le cas, elle va sérialiser les
  210. variables de la vue en <acronym>JSON</acronym>, et envoyer la réponse&#160;;
  211. mais dans le cas contraire, elle va réactiver le ViewRenderer.
  212. </para>
  213. </listitem>
  214. </itemizedlist>
  215. <para>Voici les méthodes d'interaction avec les contextes&#160;:</para>
  216. <itemizedlist>
  217. <listitem>
  218. <para>
  219. <methodname>addContext($context, array $spec)</methodname>&#160;: Ajoute un
  220. nouveau contexte. Si celui-ci existe déjà, une exception sera lancée.
  221. </para>
  222. </listitem>
  223. <listitem>
  224. <para>
  225. <methodname>setContext($context, array $spec)</methodname>&#160;: Ajoute un
  226. nouveau contexte, mais écrase celui-ci s'il existait déjà. Utilise les mêmes
  227. spécifications que <methodname>addContext()</methodname>.
  228. </para>
  229. </listitem>
  230. <listitem>
  231. <para>
  232. <methodname>addContexts(array $contexts)</methodname>&#160;: Ajoute plusieurs
  233. contextes d'un coup. Le tableau <varname>$contexts</varname> doit être un
  234. tableau de paires contexte et specifications. Si un des contextes existe déjà,
  235. une exception est lancée.
  236. </para>
  237. </listitem>
  238. <listitem>
  239. <para>
  240. <methodname>setContexts(array $contexts)</methodname>&#160;: Ajoute des
  241. nouveaux contextes, mais écrase ceux déjà présents éventuellement. Utilise
  242. les mêmes spécifications que <methodname>addContexts()</methodname>.
  243. </para>
  244. </listitem>
  245. <listitem>
  246. <para>
  247. <methodname>hasContext($context)</methodname>&#160;: retourne
  248. <constant>TRUE</constant> si le contexte existe déjà,
  249. <constant>FALSE</constant> sinon.
  250. </para>
  251. </listitem>
  252. <listitem>
  253. <para>
  254. <methodname>getContext($context)</methodname>&#160;: retourne un contexte
  255. par son nom. Le retour est un tableau qui a la même syntaxe que celui utilisé
  256. par <methodname>addContext()</methodname>.
  257. </para>
  258. </listitem>
  259. <listitem>
  260. <para>
  261. <methodname>getContexts()</methodname>&#160;: retourne tous les contextes.
  262. Le tableau de retour est de la forme contexte =&gt; spécifications.
  263. </para>
  264. </listitem>
  265. <listitem>
  266. <para>
  267. <methodname>removeContext($context)</methodname>&#160;: Supprime un contexte
  268. grâce à son nom. Retourne <constant>TRUE</constant> si réussi,
  269. <constant>FALSE</constant> si le contexte n'a pas été trouvé.
  270. </para>
  271. </listitem>
  272. <listitem>
  273. <para>
  274. <methodname>clearContexts()</methodname>&#160;: Supprime tous les contextes.
  275. </para>
  276. </listitem>
  277. </itemizedlist>
  278. </sect4>
  279. <sect4 id="zend.controller.actionhelpers.contextswitch.actions">
  280. <title>Affecter des contextes par action</title>
  281. <para>
  282. Il existe deux mécanismes pour créer et affecter des contextes. Vous pouvez créer
  283. des tableaux dans vos contrôleurs, ou utiliser plusieurs méthodes de
  284. <emphasis>ContextSwitch</emphasis> pour les assembler.
  285. </para>
  286. <para>
  287. La méthode principale pour ajouter des contextes à des actions est
  288. <methodname>addActionContext()</methodname>. Elle attend 2 arguments, l'action et le
  289. contexte (ou un tableau de contextes). Par exemple, considérons la classe
  290. suivante&#160;:
  291. </para>
  292. <programlisting language="php"><![CDATA[
  293. class FooController extends Zend_Controller_Action
  294. {
  295. public function listAction()
  296. {
  297. }
  298. public function viewAction()
  299. {
  300. }
  301. public function commentsAction()
  302. {
  303. }
  304. public function updateAction()
  305. {
  306. }
  307. }
  308. ]]></programlisting>
  309. <para>
  310. Imaginons que nous voulions ajouter un contexte <acronym>XML</acronym> à l'action
  311. "list", et deux contextes <acronym>XML</acronym> et <acronym>JSON</acronym> à
  312. l'action "comments". Nous pourrions faire ceci dans la méthode
  313. <methodname>init()</methodname>&#160;:
  314. </para>
  315. <programlisting language="php"><![CDATA[
  316. class FooController extends Zend_Controller_Action
  317. {
  318. public function init()
  319. {
  320. $this->_helper->contextSwitch()
  321. ->addActionContext('list', 'xml')
  322. ->addActionContext('comments', array('xml', 'json'))
  323. ->initContext();
  324. }
  325. }
  326. ]]></programlisting>
  327. <para>
  328. De la même manière, il est aussi possible de simplement définir la propriété
  329. <varname>$contexts</varname>&#160;:
  330. </para>
  331. <programlisting language="php"><![CDATA[
  332. class FooController extends Zend_Controller_Action
  333. {
  334. public $contexts = array(
  335. 'list' => array('xml'),
  336. 'comments' => array('xml', 'json')
  337. );
  338. public function init()
  339. {
  340. $this->_helper->contextSwitch()->initContext();
  341. }
  342. }
  343. ]]></programlisting>
  344. <para>Cette syntaxe est simplement moins pratique et plus prompte aux erreurs.</para>
  345. <para>Pour construire vos contextes, les méthodes suivantes vous seront utiles&#160;:</para>
  346. <itemizedlist>
  347. <listitem>
  348. <para>
  349. <methodname>addActionContext($action, $context)</methodname>&#160;: Ajoute un
  350. ou plusieurs contextes à une action. <varname>$context</varname> doit donc être
  351. une chaîne, ou un tableau de chaînes.
  352. </para>
  353. <para>
  354. Passer la valeur <constant>TRUE</constant> comme contexte marquera tous les
  355. contextes comme disponibles pour cette action.
  356. </para>
  357. <para>
  358. Une valeur vide pour <varname>$context</varname> désactivera tous les contextes
  359. donnés à cette action.
  360. </para>
  361. </listitem>
  362. <listitem>
  363. <para>
  364. <methodname>setActionContext($action, $context)</methodname>&#160;: Marque un
  365. ou plusieurs contextes comme disponibles pour cette action. Si ceux-ci existent
  366. déjà, ils seront remplacés. <varname>$context</varname> doit être une chaîne ou
  367. un tableau de chaînes.
  368. </para>
  369. </listitem>
  370. <listitem>
  371. <para>
  372. <methodname>addActionContexts(array $contexts)</methodname>&#160;: Ajoute
  373. plusieurs paires action et contexte en une fois. <varname>$contexts</varname>
  374. doit être un tableau associatif action et contexte. Cette méthode proxie vers
  375. <methodname>addActionContext()</methodname>.
  376. </para>
  377. </listitem>
  378. <listitem>
  379. <para>
  380. <methodname>setActionContexts(array $contexts)</methodname>&#160;: agit comme
  381. <methodname>addActionContexts()</methodname>, mais écrase les paires
  382. action et contexte existantes.
  383. </para>
  384. </listitem>
  385. <listitem>
  386. <para>
  387. <methodname>hasActionContext($action, $context)</methodname>&#160;: détermine
  388. si une action possède un contexte donné.
  389. </para>
  390. </listitem>
  391. <listitem>
  392. <para>
  393. <methodname>getActionContexts($action = null)</methodname>&#160;: Retourne tous
  394. les contextes d'une action donnée, si pas d'action passée, retourne alors toutes
  395. les paires action et contexte.
  396. </para>
  397. </listitem>
  398. <listitem>
  399. <para>
  400. <methodname>removeActionContext($action, $context)</methodname>&#160;: Supprime
  401. un ou plusieurs contextes pour une action. <varname>$context</varname> doit être
  402. une chaîne ou un tableau de chaînes.
  403. </para>
  404. </listitem>
  405. <listitem>
  406. <para>
  407. <methodname>clearActionContexts($action = null)</methodname>&#160;: Supprime
  408. tous les contextes d'une action. Si aucune action n'est spécifiée, supprime
  409. alors tous les contextes de toutes les actions.
  410. </para>
  411. </listitem>
  412. </itemizedlist>
  413. </sect4>
  414. <sect4 id="zend.controller.actionhelpers.contextswitch.initcontext">
  415. <title>Initialiser le Context Switch</title>
  416. <para>
  417. Pour initialiser la permutation de contextes (contexte switching), vous devez
  418. appeler <methodname>initContext()</methodname> dans vos contrôleurs d'action&#160;:
  419. </para>
  420. <programlisting language="php"><![CDATA[
  421. class NewsController extends Zend_Controller_Action
  422. {
  423. public function init()
  424. {
  425. $this->_helper->contextSwitch()->initContext();
  426. }
  427. }
  428. ]]></programlisting>
  429. <para>
  430. Dans certains cas, vous voudriez forcer un contexte pour une action&#160;; par exemple
  431. vous pouvez vouloir seulement le contexte <acronym>XML</acronym> si la permutation de
  432. contexte est active. Passez le alors à <methodname>initContext()</methodname>&#160;:
  433. </para>
  434. <programlisting language="php"><![CDATA[
  435. $contextSwitch->initContext('xml');
  436. ]]></programlisting>
  437. </sect4>
  438. <sect4 id="zend.controller.actionhelpers.contextswitch.misc">
  439. <title>Fonctionnalités avancées</title>
  440. <para>
  441. Voici quelques méthodes qui peuvent être utilisées pour changer le comportement
  442. de l'aide <emphasis>ContextSwitch</emphasis>&#160;:
  443. </para>
  444. <itemizedlist>
  445. <listitem>
  446. <para>
  447. <methodname>setAutoJsonSerialization($flag)</methodname>: Par défaut, le
  448. contexte <acronym>JSON</acronym> va sérialiser toute variable en notation
  449. <acronym>JSON</acronym> et les retourner en tant que réponse. Si vous voulez
  450. créer votre propre réponse, vous voudriez désactiver cet effet. Ceci doit être
  451. fait avant l'appel à <methodname>initContext()</methodname>.
  452. </para>
  453. <programlisting language="php"><![CDATA[
  454. $contextSwitch->setAutoJsonSerialization(false);
  455. $contextSwitch->initContext();
  456. ]]></programlisting>
  457. <para>
  458. Pour récupérer la valeur actuelle, utilisez
  459. <methodname>getAutoJsonSerialization()</methodname>.
  460. </para>
  461. </listitem>
  462. <listitem>
  463. <para>
  464. <methodname>setSuffix($context, $suffix,
  465. $prependViewRendererSuffix)</methodname>&#160;:
  466. Cette méthode permet de personnaliser le suffixe de vue d'un contexte. Le
  467. troisième argument indique si le suffixe actuel du ViewRenderer doit être
  468. utilisé comme préfixe de votre suffixe. Par défaut, c'est le cas.
  469. </para>
  470. <para>
  471. Passer une valeur vide au suffixe aura pour effet de n'utiliser que le
  472. suffixe du ViewRenderer.
  473. </para>
  474. </listitem>
  475. <listitem>
  476. <para>
  477. <methodname>addHeader($context, $header, $content)</methodname>&#160;: Ajoute
  478. un en-tête à la réponse pour un contexte donné. <varname>$header</varname>
  479. est le nom de l'en-tête et <varname>$content</varname> sa valeur.
  480. </para>
  481. <para>
  482. Chaque contexte peut posséder plusieurs en-têtes,
  483. <methodname>addHeader()</methodname> ajoute des en-têtes dans une pile,
  484. pour un contexte donné.
  485. </para>
  486. <para>
  487. Si l'en-tête <varname>$header</varname> spécifié pour le contexte existe déjà,
  488. une exception sera alors levée.
  489. </para>
  490. </listitem>
  491. <listitem>
  492. <para>
  493. <methodname>setHeader($context, $header, $content)</methodname>&#160;:
  494. <methodname>setHeader()</methodname> agit comme
  495. <methodname>addHeader()</methodname>, sauf qu'il va écraser un en-tête
  496. qui aurait déjà été présent.
  497. </para>
  498. </listitem>
  499. <listitem>
  500. <para>
  501. <methodname>addHeaders($context, array $headers)</methodname>&#160;: Ajoute
  502. plusieurs en-têtes en une seule fois. Proxie vers
  503. <methodname>addHeader()</methodname>.<varname>$headers</varname> est un
  504. tableau de paires header =&gt; contexte.
  505. </para>
  506. </listitem>
  507. <listitem>
  508. <para>
  509. <methodname>setHeaders($context, array $headers.)</methodname>&#160;: comme
  510. <methodname>addHeaders()</methodname>, sauf que cette méthode proxie vers
  511. <methodname>setHeader()</methodname>, vous permettant d'écraser des en-têtes
  512. déjà présents.
  513. </para>
  514. </listitem>
  515. <listitem>
  516. <para>
  517. <methodname>getHeader($context, $header)</methodname>&#160;: retourne une
  518. valeur d'en-tête pour un contexte. Retourne <constant>NULL</constant>
  519. si non trouvé.
  520. </para>
  521. </listitem>
  522. <listitem>
  523. <para>
  524. <methodname>removeHeader($context, $header)</methodname>&#160;: supprime
  525. un en-tête d'un contexte.
  526. </para>
  527. </listitem>
  528. <listitem>
  529. <para>
  530. <methodname>clearHeaders($context, $header)</methodname>&#160;: supprime
  531. tous les en-têtes d'un contexte.
  532. </para>
  533. </listitem>
  534. <listitem>
  535. <para>
  536. <methodname>setCallback($context, $trigger, $callback)</methodname>&#160;:
  537. affecte une fonction de rappel (callback) pour un contexte. Le déclencheur
  538. peut être soit "init" ou "post" (la fonction de rappel sera appelée soit à
  539. l'initialisation du contexte, ou à la fin, en postDispatch).
  540. <varname>$callback</varname> doit être un nom de fonction <acronym>PHP</acronym>
  541. valide.
  542. </para>
  543. </listitem>
  544. <listitem>
  545. <para>
  546. <methodname>setCallbacks($context, array $callbacks)</methodname>&#160;:
  547. affecte plusieurs fonctions de rappel pour un contexte.
  548. <varname>$callbacks</varname> doit être un tableau de paires trigger et
  549. callback. Actuellement, seules deux fonctions maximum peuvent être enregistrées
  550. car il n'existe que 2 déclencheurs (triggers)&#160;: "init" et "post".
  551. </para>
  552. </listitem>
  553. <listitem>
  554. <para>
  555. <methodname>getCallback($context, $trigger)</methodname>&#160;: retourne un
  556. nom de fonction de rappel affectée à un contexte.
  557. </para>
  558. </listitem>
  559. <listitem>
  560. <para>
  561. <methodname>getCallbacks($context)</methodname>&#160;: retourne un tableau
  562. de paires trigger et callback pour un contexte.
  563. </para>
  564. </listitem>
  565. <listitem>
  566. <para>
  567. <methodname>removeCallback($context, $trigger)</methodname>&#160;: supprime
  568. une fonction de rappel d'un contexte.
  569. </para>
  570. </listitem>
  571. <listitem>
  572. <para>
  573. <methodname>clearCallbacks($context)</methodname>&#160;: supprime toutes
  574. les fonctions de rappel d'un contexte.
  575. </para>
  576. </listitem>
  577. <listitem>
  578. <para>
  579. <methodname>setContextParam($name)</methodname>&#160;: affecte le paramètre
  580. de requête à vérifier pour savoir si un contexte a été appelé. La valeur par
  581. défaut est "format".
  582. </para>
  583. <para>
  584. <methodname>getContextParam()</methodname> en retourne la valeur actuelle.
  585. </para>
  586. </listitem>
  587. <listitem>
  588. <para>
  589. <methodname>setAutoDisableLayout($flag)</methodname>&#160;: Par défaut, les
  590. layouts sont désactivées lorsqu'un contexte intervient, ceci provient du fait
  591. que les layouts n'ont en théorie pas de signification particulière pour un
  592. contexte, mais plutôt pour une réponse 'normale'. Cependant si vous désirez
  593. utiliser les layouts pour des contexte, passez alors la valeur
  594. <constant>FALSE</constant> à <methodname>setAutoDisableLayout()</methodname>.
  595. Ceci devant être fait <emphasis>avant</emphasis> l'appel à
  596. <methodname>initContext()</methodname>.
  597. </para>
  598. <para>
  599. Pour récupérer la valeur de ce paramètre, utilisez
  600. <methodname>getAutoDisableLayout()</methodname>.
  601. </para>
  602. </listitem>
  603. <listitem>
  604. <para>
  605. <methodname>getCurrentContext()</methodname> est utilisée pour savoir quel
  606. contexte a été détecté (si c'est le cas). Cette méthode retourne
  607. <constant>NULL</constant> si aucune permutation de contexte a été détectée,
  608. ou si elle est appelée avant <methodname>initContext()</methodname>.
  609. </para>
  610. </listitem>
  611. </itemizedlist>
  612. </sect4>
  613. <sect4 id="zend.controller.actionhelpers.contextswitch.ajaxcontext">
  614. <title>Fonctionnalité AjaxContext</title>
  615. <para>
  616. L'aide <emphasis>AjaxContext</emphasis> étend l'aide de permutation de contexte
  617. <emphasis>ContextSwitch</emphasis>, donc toutes les fonctionnalités de
  618. <emphasis>ContextSwitch</emphasis> s'y retrouvent. Il y a cependant quelques
  619. différences&#160;:
  620. </para>
  621. <para>
  622. Cette aide utilise une propriété de contrôleur d'action différente pour
  623. déterminer les contextes, <varname>$ajaxable</varname>. Vous pouvez avoir différents
  624. contextes utilisés avec les requêtes <acronym>AJAX</acronym> ou <acronym>HTTP</acronym>.
  625. Les différentes méthodes <methodname>ActionContext()</methodname> de
  626. <emphasis>AjaxContext</emphasis> vont écrire dans cette propriété.
  627. </para>
  628. <para>
  629. De plus, cette aide ne sera déclenchée que si la requête répond au critère
  630. <methodname>isXmlHttpRequest()</methodname>. Donc même si le paramètre "format" est
  631. passée à la requête, il faut nécessairement que celle ci soit une requête
  632. XmlHttpRequest, sinon la permutation de contexte n'aura pas lieu.
  633. </para>
  634. <para>
  635. Enfin, <emphasis>AjaxContext</emphasis> ajoute un contexte, <acronym>HTML</acronym>.
  636. Dans ce contexte, le suffixe de vue est "<filename>ajax.phtml</filename>". Il n'y a
  637. pas d'en-tête particulier ajouté à la réponse.
  638. </para>
  639. <example id="zend.controller.actionhelpers.contextswitch.ajaxcontext.example">
  640. <title>Autoriser les actions à répondre aux requêtes AJAX</title>
  641. <para>
  642. Dans l'exemple qui suit, nous autorisons les actions "view", "form", et
  643. "process" à répondre aux requêtes <acronym>AJAX</acronym>. Dans les actions,
  644. "view" et "form", nous retournerons des portions de <acronym>HTML</acronym>&#160;;
  645. dans "process", nous retournerons du <acronym>JSON</acronym>.
  646. </para>
  647. <programlisting language="php"><![CDATA[
  648. class CommentController extends Zend_Controller_Action
  649. {
  650. public function init()
  651. {
  652. $ajaxContext = $this->_helper->getHelper('AjaxContext');
  653. $ajaxContext->addActionContext('view', 'html')
  654. ->addActionContext('form', 'html')
  655. ->addActionContext('process', 'json')
  656. ->initContext();
  657. }
  658. public function viewAction()
  659. {
  660. // Voir les commentaires.
  661. // Quand le AjaxContext est détecté, il utilise le script de vue
  662. // comment/view.ajax.phtml
  663. }
  664. public function formAction()
  665. {
  666. // Rend les formulaire "ajoutez un commentaire".
  667. // Lorsque le AjaxContext est détecté, il utilise le script de
  668. // vue : comment/form.ajax.phtml
  669. }
  670. public function processAction()
  671. {
  672. // Traite un commentaire
  673. // Retourne les résultats sous forme JSON ; assignez simplement
  674. // vos résultats comme variables de vues.
  675. }
  676. }
  677. ]]></programlisting>
  678. <para>
  679. Coté client, votre bibliothèque <acronym>AJAX</acronym> requêtera simplement
  680. "<filename>/comment/view</filename>",
  681. "<filename>/comment/form</filename>", et "<filename>/comment/process</filename>",
  682. en passant le paramètre "format"&#160;:
  683. "<filename>/comment/view/format/html</filename>",
  684. "<filename>/comment/form/format/html</filename>",
  685. "<filename>/comment/process/format/json</filename>".
  686. (Ceci fonctionne aussi avec "?format=json".)
  687. </para>
  688. <para>
  689. Il est nécessaire que votre bibliothèque envoie l'en-tête
  690. "X-Requested-With: XmlHttpRequest", ce qui est en général le cas.
  691. </para>
  692. </example>
  693. </sect4>
  694. </sect3>