view-placeholders-standard.xml 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 22189 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="learning.view.placeholders.standard">
  5. <title>Placeholders standards</title>
  6. <para>
  7. Dans la <link linkend="learning.view.placeholders.basics">section précédente</link>, nous
  8. avons vu l'aide de vue <methodname>placeholder()</methodname> et comment l'utiliser pour
  9. aggréger du contenu personnalisable. Dans ce chapitre, nous allons passer en revue quelques
  10. placeholders concrets fournis avec Zend Framework, ainsi que la manière de les utiliser à
  11. votre avantage pour créer des layouts complexes.
  12. </para>
  13. <para>
  14. La plupart des placeholders fournis permettent de gérer le contenur de la section
  15. <emphasis>&lt;head&gt;</emphasis> de la layout -- une zone qui ne peut typiquement pas être
  16. manipulée directement par vos scripts de vue, mais que vous voulez tout de même traiter.
  17. Par exemples: vous voudriez que votre titre se compose d'un certain contenu sur toutes les
  18. pages mais aussi d'une partie dynamique relative au contrôleur/action en cours; aussi vous
  19. voudriez préciser des fichiers <acronym>CSS</acronym> à charger basés sur la section de
  20. l'application en cours; enfin vous pourriez avoir recours à des scripts JavaScript spécifiques
  21. parfois, ou encore changer la déclaration de <acronym>DocType</acronym>.
  22. </para>
  23. <para>
  24. Zend Framework est livré avec des implémentations de placeholder pour chacune de ces situations
  25. et encore d'autres.
  26. </para>
  27. <sect2 id="learning.view.placeholders.standard.doctype">
  28. <title>Changer le DocType</title>
  29. <para>
  30. Les déclarations de <acronym>DocType</acronym> sont difficiles à mémoriser et souvent
  31. essentielles pour s'assurer que le navigateur rende correctement le contenu. L'aide de vue
  32. <methodname>doctype()</methodname> permet d'utiliser des mnemonics pour spécifier un
  33. <acronym>DocType</acronym>; aussi, d'autres aides de vues interrogeront l'aide
  34. <methodname>doctype()</methodname> pour s'assurer que le contenu qu'elles génèrent est
  35. conforme au <acronym>DocType</acronym> utilisé.
  36. </para>
  37. <para>
  38. Par exemple si vous souhaitez utiliser la <acronym>DTD</acronym>
  39. <acronym>XHTML1</acronym> Strict, vous pouvez simplement la préciser
  40. comme ceci:
  41. </para>
  42. <programlisting language="php"><![CDATA[
  43. $this->doctype('XHTML1_STRICT');
  44. ]]></programlisting>
  45. <para>
  46. Voici les autres mnemonics utilisables:
  47. </para>
  48. <variablelist>
  49. <varlistentry>
  50. <term>XHTML1_STRICT</term>
  51. <listitem>
  52. <para>
  53. <acronym>XHTML</acronym> 1.0 Strict
  54. </para>
  55. </listitem>
  56. </varlistentry>
  57. <varlistentry>
  58. <term>XHTML1_TRANSITIONAL</term>
  59. <listitem>
  60. <para>
  61. <acronym>XHTML</acronym> 1.0 Transitional
  62. </para>
  63. </listitem>
  64. </varlistentry>
  65. <varlistentry>
  66. <term>HTML4_STRICT</term>
  67. <listitem>
  68. <para>
  69. <acronym>HTML</acronym> 4.01 Strict
  70. </para>
  71. </listitem>
  72. </varlistentry>
  73. <varlistentry>
  74. <term>HTML4_Loose</term>
  75. <listitem>
  76. <para>
  77. <acronym>HTML</acronym> 4.01 Loose
  78. </para>
  79. </listitem>
  80. </varlistentry>
  81. <varlistentry>
  82. <term>HTML5</term>
  83. <listitem>
  84. <para>
  85. <acronym>HTML</acronym> 5
  86. </para>
  87. </listitem>
  88. </varlistentry>
  89. </variablelist>
  90. <para>
  91. Vous pouvez changer le type et rendre la déclaration en un seul appel:
  92. </para>
  93. <programlisting language="php"><![CDATA[
  94. echo $this->doctype('XHTML1_STRICT');
  95. ]]></programlisting>
  96. <para>
  97. Cependant l'approche conseillée est de préciser le type dans le bootstrap et rendre l'aide
  98. de vue dans la layout. Essayez d'ajouter ceci à votre classe de bootstrap:
  99. </para>
  100. <programlisting language="php"><![CDATA[
  101. class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
  102. {
  103. protected function _initDocType()
  104. {
  105. $this->bootstrap('View');
  106. $view = $this->getResource('View');
  107. $view->doctype('XHTML1_STRICT');
  108. }
  109. }
  110. ]]></programlisting>
  111. <para>
  112. Puis, dans le script de layout, affichez simplement avec <function>echo</function> l'aide en
  113. haut du fichier:
  114. </para>
  115. <programlisting language="php"><![CDATA[
  116. <?php echo $this->doctype() ?>
  117. <html>
  118. <!-- ... -->
  119. ]]></programlisting>
  120. <para>
  121. Ceci permet d'être sûr que les aides de vue diverses utiliseront cette déclaration,
  122. que le docType est précisé avant le rendu du layout et qu'il n'existe qu'un seul endroit
  123. logique pour le changer.
  124. </para>
  125. </sect2>
  126. <sect2 id="learning.view.placeholders.standard.head-title">
  127. <title>Spécifier le titre de la page</title>
  128. <para>
  129. Souvent, le site incluera le nom de la société dans le titre de la page et ajoutera
  130. ensuite des informations basées sur la page en cours de lecture. Par exemple, le site
  131. zend.com inclut la chaine "Zend.com" sur toutes les pages et y fait précèder des
  132. informations relatives à la page en cours: "Zend Server - Zend.com". Dans Zend Framework,
  133. l'aide de vue <methodname>headTitle()</methodname> peut vous simplifier cette tâche.
  134. </para>
  135. <para>
  136. Au plus simple, l'aide <methodname>headTitle()</methodname> permet d'aggréger du contenu
  137. pour la balise <emphasis>&lt;title&gt;</emphasis>; lorsque vous l'affichez, il assemble
  138. son contenu dans l'ordre des ajouts. Pour contrôler l'ordre, les méthodes
  139. <methodname>prepend()</methodname> et <methodname>append()</methodname> sont là, pour changer
  140. le séparateur à utiliser entre les segments, utilisez la méthode
  141. <methodname>setSeparator()</methodname>.
  142. </para>
  143. <para>
  144. Typiquement vous devriez renseigner tous les segments communs à toutes les pages en bootstrap,
  145. de la même manière que nous avions agit avec le doctype. Dans ce cas, nous allons écrire une
  146. méthode <methodname>_initPlaceholders()</methodname> pour gérer tous les placeholders et préciser
  147. un titre initial ainsi qu'un séparateur.
  148. </para>
  149. <programlisting language="php"><![CDATA[
  150. class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
  151. {
  152. // ...
  153. protected function _initPlaceholders()
  154. {
  155. $this->bootstrap('View');
  156. $view = $this->getResource('View');
  157. $view->doctype('XHTML1_STRICT');
  158. // Précise le titre initial et le séparateur:
  159. $view->headTitle('My Site')
  160. ->setSeparator(' :: ');
  161. }
  162. // ...
  163. }
  164. ]]></programlisting>
  165. <para>
  166. Dans un script de vue, nous voulons ajouter un nouveau segment:
  167. </para>
  168. <programlisting language="php"><![CDATA[
  169. <?php $this->headTitle()->append('Some Page'); // placé après les autres segments ?>
  170. <?php $this->headTitle()->prepend('Some Page'); // placé avant ?>
  171. ]]></programlisting>
  172. <para>
  173. Dans notre layout, nous affichons simplement l'aide <methodname>headTitle()</methodname>:
  174. </para>
  175. <programlisting language="php"><![CDATA[
  176. <?php echo $this->doctype() ?>
  177. <html>
  178. <?php echo $this->headTitle() ?>
  179. <!-- ... -->
  180. ]]></programlisting>
  181. <para>
  182. Le contenu suivant aura été généré:
  183. </para>
  184. <programlisting language="html"><![CDATA[
  185. <!-- Si append() a été utilisé: -->
  186. <title>My Site :: Some Page</title>
  187. <!-- Si prepend() a été utilisé: -->
  188. <title>Some Page :: My Site</title>
  189. ]]></programlisting>
  190. </sect2>
  191. <sect2 id="learning.view.placeholders.standard.head-link">
  192. <title>Spécifier des feuilles de style avec HeadLink</title>
  193. <para>
  194. Les bons développeurs <acronym>CSS</acronym> créront souvent une feuille de style
  195. globale et des feuilles individuelles pour les sections spécifiques ou certaines pages
  196. du site puis chargeront celles-ci plus tard conditionnellement afin de réduire
  197. le nombre de données à transférer entre chaque requête. Le placeholder
  198. <methodname>headLink()</methodname> permet de réaliser de telles aggrégations
  199. conditionnelles de feuilles de style.
  200. </para>
  201. <para>
  202. Pour cela, <methodname>headLink()</methodname> definit une certain nombre de méthodes
  203. "virtuelles" (via surcharge) pour simplifier le tout. Celles qui vont nous concernet
  204. sont <methodname>appendStylesheet()</methodname> et
  205. <methodname>prependStylesheet()</methodname>. Chacune peut accepter jusqu'à quatre
  206. arguments, <varname>$href</varname> (chemin relatif vers la feuille de style),
  207. <varname>$media</varname> (le type <acronym>MIME</acronym>, par défaut "text/css"),
  208. <varname>$conditionalStylesheet</varname> (à utiliser pour préciser une "condition"
  209. à évaluer pour la feuille de style), et <varname>$extras</varname> (un tableau
  210. associatif utiliser générallement pour renseigner une clé pour "media"). Dans la
  211. plupart des cas, seul le premier argument suffira, le chemin relatif vers la feuille
  212. de style.
  213. </para>
  214. <para>
  215. Dans notre exemple, nous supposerons que toutes les pages ont besoin de charger une feuille
  216. de style stockée dans "<filename>/styles/site.css</filename>" (relativement au document root);
  217. nous allons préciser cela dans notre méthode de bootstrap
  218. <methodname>_initPlaceholders()</methodname>.
  219. </para>
  220. <programlisting language="php"><![CDATA[
  221. class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
  222. {
  223. // ...
  224. protected function _initPlaceholders()
  225. {
  226. $this->bootstrap('View');
  227. $view = $this->getResource('View');
  228. $view->doctype('XHTML1_STRICT');
  229. // Affecte le titre original et le séparateur:
  230. $view->headTitle('My Site')
  231. ->setSeparator(' :: ');
  232. // Affecte la feuille de style originale:
  233. $view->headLink()->prependStylesheet('/styles/site.css');
  234. }
  235. // ...
  236. }
  237. ]]></programlisting>
  238. <para>
  239. Plus tard, dans un contrôleur par exemple, nous pouvons rajouter des feuilles de
  240. style:
  241. </para>
  242. <programlisting language="php"><![CDATA[
  243. <?php $this->headLink()->appendStylesheet('/styles/user-list.css') ?>
  244. ]]></programlisting>
  245. <para>
  246. Dans notre layout, là encore, un simple echo sur le placeholer:
  247. </para>
  248. <programlisting language="php"><![CDATA[
  249. <?php echo $this->doctype() ?>
  250. <html>
  251. <?php echo $this->headTitle() ?>
  252. <?php echo $this->headLink() ?>
  253. <!-- ... -->
  254. ]]></programlisting>
  255. <para>
  256. Ceci génèrera quelque chose comme:
  257. </para>
  258. <programlisting language="html"><![CDATA[
  259. <link rel="stylesheet" type="text/css" href="/styles/site.css" />
  260. <link rel="stylesheet" type="text/css" href="/styles/user-list.css" />
  261. ]]></programlisting>
  262. </sect2>
  263. <sect2 id="learning.view.placeholders.standard.head-script">
  264. <title>Aggréger des scripts avec HeadScript</title>
  265. <para>
  266. Un autre moyen de ne pas surcharger la page est de ne charger le JavaScript que lorsque
  267. c'est nécessaire. Vous aurez donc besoin de scripts découpés: peut-être un pour afficher
  268. le menu du site progressivement, un autre pour traiter le contenu d'une page spécifique.
  269. Dans ces cas, l'aide <methodname>headScript()</methodname> propose une solution.
  270. </para>
  271. <para>
  272. Comme l'aide <methodname>headLink()</methodname>, <methodname>headScript()</methodname>
  273. permet d'empiler en début ou fin des scripts entiers et de les afficher d'un coup. Cela
  274. est très flexible pour spécifier des fichiers de scripts entiers à charger, ou encore
  275. du code JavaScript explicite. Vous pouvez aussi capturer le JavaScript via
  276. <methodname>captureStart()</methodname>/<methodname>captureEnd()</methodname>, qui
  277. permettent d'utiliser du code JavaScript inline plutot que de demander un appel serveur
  278. pour charger un fichier.
  279. </para>
  280. <para>
  281. Tout comme <methodname>headLink()</methodname>, <methodname>headScript()</methodname>
  282. propose des mééthodes "virtuelles" via surcharge pour spécifier rapidement des contenus
  283. à aggréger; les méthodes sont <methodname>prependFile()</methodname>,
  284. <methodname>appendFile()</methodname>, <methodname>prependScript()</methodname>, et
  285. <methodname>appendScript()</methodname>. Les deux premières vous permettent de préciser
  286. des fichiers référéncés dans l'attribut <varname>$src</varname> d'une balise
  287. <emphasis>&lt;script&gt;</emphasis>; les deux dernières vont prendre le contenu qu'on leur
  288. passe et le rendre comme du JavaScript dans les balises <emphasis>&lt;script&gt;</emphasis>.
  289. </para>
  290. <para>
  291. Dans cet exemple, nous allons spécifier qu'un script, "<filename>/js/site.js</filename>" a
  292. besoin d'être chargé sur chaque page; nous allons donc mettre à jour notre méthode de
  293. bootstap <methodname>_initPlaceholders()</methodname> pour effectuer cela.
  294. </para>
  295. <programlisting language="php"><![CDATA[
  296. class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
  297. {
  298. // ...
  299. protected function _initPlaceholders()
  300. {
  301. $this->bootstrap('View');
  302. $view = $this->getResource('View');
  303. $view->doctype('XHTML1_STRICT');
  304. // Titre et séparateur d'origine:
  305. $view->headTitle('My Site')
  306. ->setSeparator(' :: ');
  307. // Feuille de style originale:
  308. $view->headLink()->prependStylesheet('/styles/site.css');
  309. // Affecte le JS initial à charger:
  310. $view->headScript()->prependFile('/js/site.js');
  311. }
  312. // ...
  313. }
  314. ]]></programlisting>
  315. <para>
  316. Dans un script de vue, nous voulons ajouter un script ou capturer du contenu JavaScript
  317. à inclure dans le document.
  318. </para>
  319. <programlisting language="php"><![CDATA[
  320. <?php $this->headScript()->appendFile('/js/user-list.js') ?>
  321. <?php $this->headScript()->captureStart() ?>
  322. site = {
  323. baseUrl: "<?php echo $this->baseUrl() ?>"
  324. };
  325. <?php $this->headScript()->captureEnd() ?>
  326. ]]></programlisting>
  327. <para>
  328. Dans notre script de layout, nous affichons simplement le placeholder, tout comme nous avions
  329. fait pour les autres précédemment:
  330. </para>
  331. <programlisting language="php"><![CDATA[
  332. <?php echo $this->doctype() ?>
  333. <html>
  334. <?php echo $this->headTitle() ?>
  335. <?php echo $this->headLink() ?>
  336. <?php echo $this->headScript() ?>
  337. <!-- ... -->
  338. ]]></programlisting>
  339. <para>
  340. Le contenu suivant sera généré:
  341. </para>
  342. <programlisting language="html"><![CDATA[
  343. <script type="text/javascript" src="/js/site.js"></script>
  344. <script type="text/javascript" src="/js/user-list.js"></script>
  345. <script type="text/javascript">
  346. site = {
  347. baseUrl: "<?php echo $this->baseUrl() ?>"
  348. };
  349. </script>
  350. ]]></programlisting>
  351. <note>
  352. <title>Variante InlineScript</title>
  353. <para>
  354. La plupart des navigateur bloquent l'affichage tant que tous les scritps et les feuilles
  355. de style référencés dans la section <emphasis>&lt;head&gt;</emphasis> ne sont pas chargés.
  356. Ces règles permettent un meilleur feeling au niveau du rendu de la page et permettent
  357. à l'utilisateur de voir le contenu de la page plus tôt.
  358. </para>
  359. <para>
  360. Pour cela, vous pouvez par exemple écrire vos tags <emphasis>&lt;script&gt;</emphasis>
  361. après avoir fermé <emphasis>&lt;body&gt;</emphasis>. (C'est une pratique recommandée
  362. par <ulink url="http://developer.yahoo.com/yslow/">Y! Slow project</ulink>.)
  363. </para>
  364. <para>
  365. Zend Framework supporte cela de deux manières différentes:
  366. </para>
  367. <itemizedlist>
  368. <listitem>
  369. <para>
  370. Vous pouvez rendre <methodname>headScript()</methodname> où vous voulez dans votre
  371. layout; ce n'est pas parce que la méthode commence par "head" que vous devez
  372. l'appeler pour cette section du HTML.
  373. </para>
  374. </listitem>
  375. <listitem>
  376. <para>
  377. Aussi, vous pourriez utiliser l'aide de vue <methodname>inlineScript()</methodname>,
  378. qui est simplement une variante de <methodname>headScript()</methodname> avec le même
  379. comportement mais un registre séparé.
  380. </para>
  381. </listitem>
  382. </itemizedlist>
  383. </note>
  384. </sect2>
  385. </sect1>