Zend_View-Helpers-HeadMeta.xml 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 19438 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.view.helpers.initial.headmeta">
  5. <title>HeadMeta Helfer</title>
  6. <para>
  7. Das HTML Element <emphasis>&lt;meta&gt;</emphasis> wird verwendet um Meta Informationen über
  8. das HTML Dokument anzubieten -- typischerweise Schlüsselwörter. Dokument Zeichensätze, Cache
  9. Pragmas, usw. Meta Tags können entweder 'http-equiv' oder 'name' Typen sein, müssen ein
  10. 'content' Attribut enthalten, und können auch eines der 'lang' oder 'scheme' Modifikator
  11. Attributen enthalten.
  12. </para>
  13. <para>
  14. Der <classname>HeadMeta</classname> Helfer unterstützt die folgenden Methoden für das Setzen
  15. und Hinzufügen von Meta Tags:
  16. </para>
  17. <itemizedlist>
  18. <listitem>
  19. <para>
  20. <command>appendName($keyValue, $content, $conditionalName)</command>
  21. </para>
  22. </listitem>
  23. <listitem>
  24. <para>
  25. <command>offsetSetName($index, $keyValue, $content, $conditionalName)</command>
  26. </para>
  27. </listitem>
  28. <listitem>
  29. <para>
  30. <command>prependName($keyValue, $content, $conditionalName)</command>
  31. </para>
  32. </listitem>
  33. <listitem>
  34. <para>
  35. <command>setName($keyValue, $content, $modifiers)</command>
  36. </para>
  37. </listitem>
  38. <listitem>
  39. <para>
  40. <command>appendHttpEquiv($keyValue, $content, $conditionalHttpEquiv)</command>
  41. </para>
  42. </listitem>
  43. <listitem>
  44. <para>
  45. <command>offsetSetHttpEquiv($index, $keyValue, $content,
  46. $conditionalHttpEquiv)</command>
  47. </para>
  48. </listitem>
  49. <listitem>
  50. <para>
  51. <command>prependHttpEquiv($keyValue, $content, $conditionalHttpEquiv)</command>
  52. </para>
  53. </listitem>
  54. <listitem>
  55. <para>
  56. <command>setHttpEquiv($keyValue, $content, $modifiers)</command>
  57. </para>
  58. </listitem>
  59. </itemizedlist>
  60. <para>
  61. Das <varname>$keyValue</varname> Element wird verwendet um einen Wert für den 'name' oder
  62. 'http-equiv' Schlüssel zu definieren; <varname>$content</varname> ist der Wert für den
  63. 'content' Schlüssel, und <varname>$modifiers</varname> ist ein optionales assoziatives Array
  64. das Schlüssel für 'land und/oder 'scheme' enthalten kann.
  65. </para>
  66. <para>
  67. Meta Tags können auch gesetzt werden indem die <methodname>headMeta()</methodname>
  68. Helfermethode verwendet wird, welche die folgende Signatur hat: <command>headMeta($content,
  69. $keyValue, $keyType = 'name', $modifiers = array(), $placement = 'APPEND')</command>.
  70. <varname>$keyValue</varname> ist der Intalt für den Schlüssel der in
  71. <varname>$keyType</varname> spezifiziert ist, und welche entweder 'name' oder 'http-equiv'
  72. sein sollte. <varname>$placement</varname> kann entweder 'SET' (überschreibt alle vorher
  73. gespeicherten Werte), 'APPEND' (fügt an das Ende des Stacks hinzu), oder 'PREPEND' (fügt an
  74. den Beginn des Stacks hinzu) sein.
  75. </para>
  76. <para>
  77. <classname>HeadMeta</classname> überschreibt <methodname>append()</methodname>,
  78. <methodname>offsetSet()</methodname>, <methodname>prepend()</methodname>, und
  79. <methodname>set()</methodname> um die Verwendung der speziellen Methoden wie oben gelistet
  80. zu erzwingen. Intern wird jedes Element als <property>stdClass</property> Token gespeichert,
  81. welches später durch Verwendung der <methodname>itemToString()</methodname> Methode
  82. serialisiert wird. Das erlaubt es Prüfungen an den Elementen im Stack durchzuführen, und
  83. diese Elemente optional zu verändern indem einfach das zurückgegebene Objekt verändert wird.
  84. </para>
  85. <para>
  86. Der <classname>HeadMeta</classname> Helfer ist eine konkrete Implementation des
  87. <link linkend="zend.view.helpers.initial.placeholder">Platzhalter Helfers</link>.
  88. </para>
  89. <example id="zend.view.helpers.initial.headmeta.basicusage">
  90. <title>Grundsätzliche Verwendung des HeadMeta Helfers</title>
  91. <para>
  92. Neue Meta Tags können jederzeit spezifiziert werden. Typischerweise werden Clientseitige
  93. Cacheregeln oder SEO Schlüsselwörter spezifiziert.
  94. </para>
  95. <para>
  96. Wenn zum Beispiel ein spezielles SEO Schlüsselwort spezifiziert werden soll, kann das
  97. durch die Erstellung eines Meta Nametags, mit dem Namen 'keywords' und dem Inhalt des
  98. Schlüsselworts das mit der Seite assoziiert werden soll, geschehen:
  99. </para>
  100. <programlisting language="php"><![CDATA[
  101. // Meta Schlüsselwörter setzen
  102. $this->headMeta()->appendName('keywords', 'framework, PHP, productivity');
  103. ]]></programlisting>
  104. <para>
  105. Wenn Clientseitige Cacheregeln gesetzt werden sollen, können http-equiv Tags mit den
  106. Regeln die erzwungen werden sollen, gesetzt werden:
  107. </para>
  108. <programlisting language="php"><![CDATA[
  109. // Clientseitiges cachen verhindern
  110. $this->headMeta()->appendHttpEquiv('expires',
  111. 'Wed, 26 Feb 1997 08:21:57 GMT')
  112. ->appendHttpEquiv('pragma', 'no-cache')
  113. ->appendHttpEquiv('Cache-Control', 'no-cache');
  114. ]]></programlisting>
  115. <para>
  116. Ein anderer populärer Verwendungszweck für Meta Tags ist das Setzen des Inhalt-Typs,
  117. Zeichensatzes, und der Sprache:
  118. </para>
  119. <programlisting language="php"><![CDATA[
  120. // Setzen des Inhalttyps und des Zeichensatzes
  121. $this->headMeta()->appendHttpEquiv('Content-Type',
  122. 'text/html; charset=UTF-8')
  123. ->appendHttpEquiv('Content-Language', 'en-US');
  124. ]]></programlisting>
  125. <para>
  126. Als letztes Beispiel, ein einfacher Weg um eine kurze Nachricht anzuzeigen bevor mit
  127. Hilfe eines "Meta Refreshes" weitergeleitet wird:
  128. </para>
  129. <programlisting language="php"><![CDATA[
  130. // Einen Meta Refresh mit 3 Sekunden zu einer neuen URL setzen:
  131. $this->headMeta()->appendHttpEquiv('Refresh',
  132. '3;URL=http://www.some.org/some.html');
  133. ]]></programlisting>
  134. <para>
  135. Wenn man bereit ist die Meta Tags im Layout zu platzieren, muß einfach der Helfer
  136. ausgegeben werden:
  137. </para>
  138. <programlisting language="php"><![CDATA[
  139. <?php echo $this->headMeta() ?>
  140. ]]></programlisting>
  141. </example>
  142. </sect3>
  143. <!--
  144. vim:se ts=4 sw=4 et:
  145. -->