Zend_View-Helpers-HeadMeta.xml 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <!-- EN-Revision: 14385 -->
  2. <sect3 id="zend.view.helpers.initial.headmeta">
  3. <title>L'aide de vue HeadMeta</title>
  4. <para>L'élément HTML <code>&lt;meta&gt;</code> est utilisé pour fournir des métadonnées concernant votre document
  5. HTML - typiquement, les mots-clés, l'encodage du document, les directives de mise en cache, etc. Les balises de
  6. métadonnées peuvent être soit de type "http-equiv" ou "name", doivent contenir un attribut "content" et peuvent
  7. avoir aussi un attribut modificateur "lang" ou "scheme".</para>
  8. <para>L'aide de vue <code>HeadMeta</code> supporte les méthodes suivantes pour le paramétrage et l'ajout de
  9. métadonnées :</para>
  10. <itemizedlist>
  11. <listitem>
  12. <para><code>appendName($keyValue, $content, $conditionalName)</code></para>
  13. </listitem>
  14. <listitem>
  15. <para><code>offsetSetName($index, $keyValue, $content, $conditionalName)</code></para>
  16. </listitem>
  17. <listitem>
  18. <para><code>prependName($keyValue, $content, $conditionalName)</code></para>
  19. </listitem>
  20. <listitem>
  21. <para><code>setName($keyValue, $content, $modifiers)</code></para>
  22. </listitem>
  23. <listitem>
  24. <para><code>appendHttpEquiv($keyValue, $content, $conditionalHttpEquiv)</code></para>
  25. </listitem>
  26. <listitem>
  27. <para><code>offsetSetHttpEquiv($index, $keyValue, $content, $conditionalHttpEquiv)</code></para>
  28. </listitem>
  29. <listitem>
  30. <para><code>prependHttpEquiv($keyValue, $content, $conditionalHttpEquiv)</code></para>
  31. </listitem>
  32. <listitem>
  33. <para><code>setHttpEquiv($keyValue, $content, $modifiers)</code></para>
  34. </listitem>
  35. </itemizedlist>
  36. <para>Le paramètre <code>$keyValue</code> est utilisé pour définir une valeur pour la clé "name" ou "http-equiv" ;
  37. <code>$content</code> est la valeur pour la clé "content", et <code>$modifiers</code> est un tableau associatif
  38. optionel qui peut contenir les clés "lang" et/ou "scheme".</para>
  39. <para>Vous pouvez aussi spécifier les métadonnées en utilisant la méthode <code>headMeta()</code> qui a la signature
  40. suivante : <code>headMeta($content, $keyValue, $keyType = 'name', $modifiers = array(), $placement =
  41. 'APPEND')</code>. <code>$keyValue</code> est le contenu de la clé spécifiée dans <code>$keyType</code>, qui peut
  42. être "name" ou "http-equiv". <code>$placement</code> peut être soit "SET" (efface toutes les valeurs sauvegardées
  43. précédentes), soit "APPEND" (ajout en fin de pile), soit "PREPEND" (ajout en début de pile).</para>
  44. <para><code>HeadMeta</code> surcharge chacune des méthodes <code>append()</code>, <code>offsetSet()</code>,
  45. <code>prepend()</code>, et <code>set()</code>, pour imposer l'utilisation des méthodes spéciales énumérées
  46. ci-dessus. En interne, il stocke chaque élément sous la forme d'un <code>stdClass</code>, qui peut ensuite être
  47. sérialiser grâce à la méthode <code>itemToString()</code>. Ceci vous permet de réaliser des contrôles sur les
  48. éléments de la pile, et optionnellement de modifier ces éléments simplement en modifiant l'objet retourné.</para>
  49. <para>L'aide de vue <code>HeadMeta</code> est une implémentation concrète de l'aide <link
  50. linkend="zend.view.helpers.initial.placeholder">Placeholder</link>.</para>
  51. <example id="zend.view.helpers.initial.headmeta.basicusage">
  52. <title>Utilisation basique de l'aide HeadMeta</title>
  53. <para>Vous pouvez spécifier une nouvelle métadonnée à n'importe quel moment. Typiquement, vous pouvez spécifier
  54. les règles de mise en cache côté client ou les mots clés SEO (Search Engine Optimization : pour l'optimisation
  55. des moteurs de recherche).</para>
  56. <para>Par exemple, si vous souhaitez spécifier des mots clés SEO, vous devez créer une métadonnée de type "name"
  57. ayant pour nom "keywords" et pour contenu les mots clés que vous souhaitez associer à votre page :</para>
  58. <programlisting role="php"><![CDATA[
  59. // paramètrage des mots clés
  60. $this->headMeta()->appendName('keywords', 'framework php productivité');
  61. ]]></programlisting>
  62. <para>Si vous souhaitez paramètrer des règles de mise en cache côté client, vous devez créer une métadonnée de
  63. type "http-equiv" avec les règles que vous souhaitez imposer :</para>
  64. <programlisting role="php"><![CDATA[
  65. // désactiver la mise en cache côté client
  66. $this->headMeta()->appendHttpEquiv('expires',
  67. 'Wed, 26 Feb 1997 08:21:57 GMT')
  68. ->appendHttpEquiv('pragma', 'no-cache')
  69. ->appendHttpEquiv('Cache-Control', 'no-cache');
  70. ]]></programlisting>
  71. <para>Une autre utilisation habituelle des métadonnées est le réglage du type de contenu ("content type"), de
  72. l'encodage, et le langage :</para>
  73. <programlisting role="php"><![CDATA[
  74. // régler le type de contenu et l'encodage
  75. $this->headMeta()->appendHttpEquiv('Content-Type', 'text/html; charset=UTF-8')
  76. ->appendHttpEquiv('Content-Language', 'fr-FR');
  77. ]]></programlisting>
  78. <para>Et comme exemple final, une manière simple d'afficher un message de transition avant une redirection est
  79. d'utiliser une métadonnée "refresh" :</para>
  80. <programlisting role="php"><![CDATA[
  81. // paramètrer une métadonnée refresh pour 3 secondes
  82. // avant une nouvel URL :
  83. $this->headMeta()->appendHttpEquiv('Refresh',
  84. '3;URL=http://www.some.org/some.html');
  85. ]]></programlisting>
  86. <para>Quand vous êtes prêts à placer vos métadonnées dans votre script de disposition, réalisez un
  87. "<code>echo</code>" de l'aide :</para>
  88. <programlisting role="php"><![CDATA[
  89. <?php echo $this->headMeta() ?>
  90. ]]></programlisting>
  91. </example>
  92. </sect3>