Zend_Layout-Advanced.xml 9.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. <!-- EN-Revision: 12891 -->
  2. <sect1 id="zend.layout.advanced">
  3. <title>Zend_Layout, utilisation avancée</title>
  4. <para><classname>Zend_Layout</classname> permet d'être utilisé de manière plus pointu.</para>
  5. <para>Vous pouvez agir sur ces éléments :</para>
  6. <itemizedlist>
  7. <listitem>
  8. <para><emphasis>Objet de vue personnalisé.</emphasis> <classname>Zend_Layout</classname> accepte tout objet de vue
  9. implémentant l'interface <classname>Zend_View_Interface</classname>.</para>
  10. </listitem>
  11. <listitem>
  12. <para><emphasis>Plugin contrôleur frontal personnalisé.</emphasis> <classname>Zend_Layout</classname> est livré avec
  13. un plugin qui rend le layout automatiquement avant de renvoyer la réponse (utilisation MVC). Vous pouvez
  14. injecter votre propre plugin.</para>
  15. </listitem>
  16. <listitem>
  17. <para><emphasis>Aide d'action personnalisée.</emphasis> <classname>Zend_Layout</classname> est livrée avec une aide
  18. d'action qui devrait en théorie suffire dans la majorité des cas. C'est un proxy vers l'objet
  19. <classname>Zend_Layout</classname>. Vous pouvez cependant utiliser votre propre classe d'aide.</para>
  20. </listitem>
  21. <listitem>
  22. <para><emphasis>Résolveur de chemin de script personnalisé</emphasis>. <classname>Zend_Layout</classname> vous permet
  23. d'utiliser votre <link linkend="zend.filter.inflector">inflecteur</link> pour la résolution des scripts de
  24. layout ou de modifier l'inflecteur par défaut.</para>
  25. </listitem>
  26. </itemizedlist>
  27. <sect2 id="zend.layout.advanced.view">
  28. <title>Objets de vue personnalisés</title>
  29. <para><classname>Zend_Layout</classname> accepte des objets de vue implémentant <classname>Zend_View_Interface</classname> ou
  30. étendant <classname>Zend_View_Abstract</classname> pour le rendu du script de layout. Passez le en paramètre au
  31. constructeur ou à <code>startMvc()</code>, ou utilisez l'accesseur <code>setView()</code> :</para>
  32. <programlisting role="php"><![CDATA[
  33. $view = new My_Custom_View();
  34. $layout->setView($view);
  35. ]]></programlisting>
  36. <note>
  37. <title>Attention à vos implémentations de Zend_View</title>
  38. <para>Même si <classname>Zend_Layout</classname> vous permet d'utiliser votre propre objet de vue (implémentant
  39. <classname>Zend_View_Interface</classname>), vous pouvez rencontrer des problèmes si votre vue n'a pas accès à
  40. certaines aides de vue, en particulier les aides "layout" et <link
  41. linkend="zend.view.helpers.initial.placeholder">"placeholder"</link>. <classname>Zend_Layout</classname> effectue des
  42. affectations de variables sur la vue via ces aides.</para>
  43. <para>Si vous avez besoin d'un objet <classname>Zend_View</classname> personnalisé qui ne supporte pas ces aides de
  44. vue, vous devrez alors trouver un moyen de passer les variables du layout à la vue. Par exemple, en étendant
  45. l'objet <classname>Zend_Layout</classname> et en rédéfinissant la méthode <code>render()</code> en passant des
  46. variables à la vue. Aussi, vous pouvez créer votre propre plugin qui s'occupe de passer ces variables avant
  47. le rendu du layout.</para>
  48. <para>De même, si votre implémentation de la vue permet l'extension via des plugins, vous pouvez à tout
  49. moment accéder aux variables du layout grâce à l'aide <link
  50. linkend="zend.view.helpers.initial.placeholder">placeholder</link> en utilisant la clé "Zend_Layout"
  51. :</para>
  52. <programlisting role="php"><![CDATA[
  53. $placeholders = new Zend_View_Helper_Placeholder();
  54. $layoutVars = $placeholders->placeholder('Zend_Layout')
  55. ->getArrayCopy();
  56. ]]></programlisting>
  57. </note>
  58. </sect2>
  59. <sect2 id="zend.layout.advanced.plugin">
  60. <title>Plugin de contrôleur frontal personnalisé</title>
  61. <para>Lorsqu'utilisé avec les composants MVC, <classname>Zend_Layout</classname> enregistre un plugin de contrôleur
  62. frontal qui se charge du rendu du layout juste avant la fin de la boucle de distribution. Ceci convient à la
  63. majorité des cas, si cependant vous avez besoin de construire votre propre plugin, passez son nom dans l'option
  64. <code>pluginClass</code> de la méthode <code>startMvc()</code>.</para>
  65. <para>Votre plugin doit alors étendre <classname>Zend_Controller_Plugin_Abstract</classname>, et devrait accepter un objet
  66. <classname>Zend_Layout</classname> lors de sa construction.</para>
  67. <para>La classe par défaut du plugin est <classname>Zend_Layout_Controller_Plugin_Layout</classname>.</para>
  68. </sect2>
  69. <sect2 id="zend.layout.advanced.helper">
  70. <title>Aide d'action personnalisée</title>
  71. <para>Si les composants MVC sont utilisés, alors <classname>Zend_Layout</classname> enregistre une classe d'aide d'action
  72. dans le gestionnaire d'aides (helper broker). Par défaut, il s'agit de
  73. <classname>Zend_Layout_Controller_Action_Helper_Layout</classname>. Cette aide agit comme un proxy vers l'instance de
  74. <classname>Zend_Layout</classname> et permet d'y accéder dans vos actions.</para>
  75. <para>Si vous voulez utiliser votre propre classe, celle-ci devra alors étendre
  76. <classname>Zend_Controller_Action_Helper_Abstract</classname>. Passez le nom de la classe dans l'option
  77. <code>helperClass</code> de la méthode <code>startMvc()</code>.</para>
  78. </sect2>
  79. <sect2 id="zend.layout.advanced.inflector">
  80. <title>Résolution de chemin de script personnalisé (inflecteur)</title>
  81. <para><classname>Zend_Layout</classname> utilise <classname>Zend_Filter_Inflector</classname> pour établir une chaine de filtre
  82. permettant la résolution du nom du layout, vers le fichier y correspondant. Par défaut, les règles
  83. "Word_CamelCaseToDash" suivie de "StringToLower" sont utilisées. Le suffixe "phtml" est ensuite ajouté :</para>
  84. <itemizedlist>
  85. <listitem>
  86. <para>"foo" sera transformé en "foo.phtml".</para>
  87. </listitem>
  88. <listitem>
  89. <para>"FooBarBaz" sera transformé vers "foo-bar-baz.phtml".</para>
  90. </listitem>
  91. </itemizedlist>
  92. <para>Vous pouvez personnaliser l'inflecteur de 3 manières différentes : Modifier la cible et/ou le suffixe
  93. grâce à des accesseurs dans <classname>Zend_Layout</classname> ; Modifier les règles de l'inflecteur associé à
  94. <classname>Zend_Layout</classname> ; Ou encore créer votre propre inflecteur et le passer à
  95. <classname>Zend_Layout::setInflector()</classname>.</para>
  96. <example id="zend.layout.advanced.inflector.accessors">
  97. <title>Utilisation des accesseurs pour modifier l'inflecteur</title>
  98. <para>L'inflecteur par défaut de <classname>Zend_Layout</classname> utilise des marqueurs statiques pour la cible et
  99. le suffixe. 2 accesseurs vous sont donc proposés :</para>
  100. <programlisting role="php"><![CDATA[
  101. // Affecte une cible à l'inflecteur:
  102. $layout->setInflectorTarget('layouts/:script.:suffix');
  103. // Affecte le suffixe:
  104. $layout->setViewSuffix('php');
  105. ]]></programlisting>
  106. </example>
  107. <example id="zend.layout.advanced.inflector.directmodification">
  108. <title>Modification directe de l'inflecteur de Zend_Layout</title>
  109. <para>Les inflecteurs fonctionnent avec un cible et plusieurs règles. La cible par défaut utilisée pour
  110. <classname>Zend_Layout</classname> est ":script.:suffix" ; ":script" représente le nom du script de layout, et
  111. ":suffix" est une règle statique.</para>
  112. <para>Imaginons que vous vouliez que le suffixe du script de layout soit "html", et que vous vouliez séparer
  113. les mots en CasseMélangée ou en notationCamel avec des tirets-bats au lieu des tirets. De plus, vous voulez
  114. chercher vos scripts dans un sous-dossier "layouts" :</para>
  115. <programlisting role="php"><![CDATA[
  116. $layout->getInflector()->setTarget('layouts/:script.:suffix')
  117. ->setStaticRule('suffix', 'html')
  118. ->setFilterRule(array('Word_CamelCaseToUnderscore'));
  119. ]]></programlisting>
  120. </example>
  121. <example id="zend.layout.advanced.inflector.custom">
  122. <title>Inflecteur personnalisé</title>
  123. <para>Dans la plupart des cas, modifier l'inflecteur sera suffisant. Vous pouvez cependant créer votre
  124. propre inflecteur, pour l'utiliser à différents endroits par exemple, et le passer à
  125. <classname>Zend_Layout</classname>:</para>
  126. <programlisting role="php"><![CDATA[
  127. $inflector = new Zend_Filter_Inflector('layouts/:script.:suffix');
  128. $inflector->addRules(array(
  129. ':script' => array('Word_CamelCaseToUnderscore'),
  130. 'suffix' => 'html'
  131. ));
  132. $layout->setInflector($inflector);
  133. ]]></programlisting>
  134. </example>
  135. <note>
  136. <title>L'inflecteur peut être désactivé</title>
  137. <para>L'inflecteur peut être désactivé si vous spécifiez, par exemple, un chemin absolu pour un script
  138. utilisé par <classname>Zend_Layout</classname>. Les méthodes <code>enableInflection()</code> et
  139. <code>disableInflection()</code> vous y aideront.</para>
  140. </note>
  141. </sect2>
  142. </sect1>