Zend_View-Helpers-HeadMeta.xml 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 17340 -->
  4. <sect3 id="zend.view.helpers.initial.headmeta">
  5. <title>HeadMeta ヘルパー</title>
  6. <para>
  7. HTML の <code>&lt;meta&gt;</code> 要素は、
  8. HTML ドキュメントに関するメタ情報を扱います。
  9. たとえばキーワードや文字セット、キャッシュ方式などです。
  10. Meta タグには 'http-equiv' 形式と 'name' 形式があり、
  11. 'content' 属性が必須となります。また、
  12. 'lang' あるいは 'scheme' のいずれかの属性を含むことができます。
  13. </para>
  14. <para>
  15. <code>HeadMeta</code> ヘルパーは、
  16. meta タグを設定したり追加したりするための次のようなメソッドを提供します。
  17. </para>
  18. <itemizedlist>
  19. <listitem><para><code>appendName($keyValue, $content,
  20. $conditionalName)</code></para></listitem>
  21. <listitem><para><code>offsetSetName($index, $keyValue, $content,
  22. $conditionalName)</code></para></listitem>
  23. <listitem><para><code>prependName($keyValue, $content,
  24. $conditionalName)</code></para></listitem>
  25. <listitem><para><code>setName($keyValue, $content,
  26. $modifiers)</code></para></listitem>
  27. <listitem><para><code>appendHttpEquiv($keyValue, $content,
  28. $conditionalHttpEquiv)</code></para></listitem>
  29. <listitem><para><code>offsetSetHttpEquiv($index, $keyValue, $content,
  30. $conditionalHttpEquiv)</code></para></listitem>
  31. <listitem><para><code>prependHttpEquiv($keyValue, $content,
  32. $conditionalHttpEquiv)</code></para></listitem>
  33. <listitem><para><code>setHttpEquiv($keyValue, $content,
  34. $modifiers)</code></para></listitem>
  35. </itemizedlist>
  36. <para>
  37. <varname>$keyValue</varname> は 'name' あるいは 'http-equiv'
  38. キーの値を定義します。<varname>$content</varname> は
  39. 'content' キーの値を定義し、<varname>$modifiers</varname>
  40. はオプションで連想配列を指定します。この配列には
  41. 'lang' や 'scheme' といったキーが含まれます。
  42. </para>
  43. <para>
  44. ヘルパーメソッド <methodname>headMeta()</methodname> で meta タグを設定することもできます。
  45. このメソッドのシグネチャは <code>headMeta($content,
  46. $keyValue, $keyType = 'name', $modifiers = array(), $placement =
  47. 'APPEND')</code>
  48. です。<varname>$keyValue</varname> には、
  49. <varname>$keyType</varname> ('name' あるいは 'http-equiv')
  50. で指定したキーのコンテンツを指定します。
  51. <varname>$placement</varname> は 'SET' (既存の値をすべて上書きする)
  52. か 'APPEND' (スタックの最後に追加する)、
  53. あるいは 'PREPEND' (スタックの先頭に追加する) となります。
  54. </para>
  55. <para>
  56. <code>HeadMeta</code> は <methodname>append()</methodname> や
  57. <methodname>offsetSet()</methodname>、<methodname>prepend()</methodname>、そして <methodname>set()</methodname>
  58. をそれぞれオーバーライドして、上にあげた特別なメソッドを使用させるようにします。
  59. 内部的には、各項目を <code>stdClass</code> のトークンとして保管し、
  60. あとで <methodname>itemToString()</methodname> メソッドでシリアライズします。
  61. これはスタック内の項目についてチェックを行い、
  62. オプションでそれを修正したものを返します。
  63. </para>
  64. <para>
  65. <code>HeadMeta</code> ヘルパーは、
  66. <link linkend="zend.view.helpers.initial.placeholder">Placeholder
  67. ヘルパー</link> の具象実装です。
  68. </para>
  69. <example id="zend.view.helpers.initial.headmeta.basicusage">
  70. <title>HeadMeta ヘルパーの基本的な使用法</title>
  71. <para>
  72. meta タグは、いつでも好きなときに指定することができます。
  73. 一般的には、クライアント側でのキャッシュの制御方法や
  74. SEO 用キーワードなどを指定します。
  75. </para>
  76. <para>
  77. たとえば、SEO 用のキーワードを指定したい場合は
  78. 'keywords' という名前の meta タグを作成します。
  79. そして、そのページに関連するキーワードを値として指定します。
  80. </para>
  81. <programlisting language="php"><![CDATA[
  82. // meta タグでキーワードを指定します
  83. $this->headMeta()->appendName('keywords', 'framework, PHP, productivity');
  84. ]]></programlisting>
  85. <para>
  86. クライアント側でのキャッシュの制御方法を指定したい場合は、
  87. http-equiv タグを設定してルールを指定します。
  88. </para>
  89. <programlisting language="php"><![CDATA[
  90. // クライアント側でのキャッシュを無効にします
  91. $this->headMeta()->appendHttpEquiv('expires',
  92. 'Wed, 26 Feb 1997 08:21:57 GMT')
  93. ->appendHttpEquiv('pragma', 'no-cache')
  94. ->appendHttpEquiv('Cache-Control', 'no-cache');
  95. ]]></programlisting>
  96. <para>
  97. meta タグの使い方としてもうひとつよくあるのは、
  98. コンテンツタイプや文字セット、言語を指定するものです。
  99. </para>
  100. <programlisting language="php"><![CDATA[
  101. // コンテンツタイプと文字セットを設定します
  102. $this->headMeta()->appendHttpEquiv('Content-Type',
  103. 'text/html; charset=UTF-8')
  104. ->appendHttpEquiv('Content-Language', 'en-US');
  105. ]]></programlisting>
  106. <para>
  107. 最後の例として、リダイレクトの前に見せるメッセージを
  108. "meta refresh" で指定するものを示します。
  109. </para>
  110. <programlisting language="php"><![CDATA[
  111. // 3 秒後に新しい URL に移動させます
  112. $this->headMeta()->appendHttpEquiv('Refresh',
  113. '3;URL=http://www.some.org/some.html');
  114. ]]></programlisting>
  115. <para>
  116. レイアウト内で meta タグを指定し終えたら、ヘルパーの内容を出力します。
  117. </para>
  118. <programlisting language="php"><![CDATA[
  119. <?php echo $this->headMeta() ?>
  120. ]]></programlisting>
  121. </example>
  122. </sect3>
  123. <!--
  124. vim:se ts=4 sw=4 et:
  125. -->