Zend_View-Helpers-HeadMeta.xml 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24868 -->
  4. <sect3 id="zend.view.helpers.initial.headmeta">
  5. <title>HeadMeta ヘルパー</title>
  6. <para>
  7. <acronym>HTML</acronym> の <emphasis>&lt;meta&gt;</emphasis> 要素は、
  8. <acronym>HTML</acronym> ドキュメントに関するメタ情報を扱います。
  9. たとえばキーワードや文字セット、キャッシュ方式などです。
  10. Meta タグには 'http-equiv' 形式と 'name' 形式があり、
  11. 'content' 属性が必須となります。また、
  12. 'lang' あるいは 'scheme' のいずれかの属性を含むことができます。
  13. </para>
  14. <para>
  15. <classname>HeadMeta</classname> ヘルパーは、
  16. meta タグを設定したり追加したりするための次のようなメソッドを提供します。
  17. </para>
  18. <itemizedlist>
  19. <listitem>
  20. <para>
  21. <command>appendName($keyValue, $content, $conditionalName)</command>
  22. </para>
  23. </listitem>
  24. <listitem>
  25. <para>
  26. <command>offsetSetName($index, $keyValue, $content, $conditionalName)</command>
  27. </para>
  28. </listitem>
  29. <listitem>
  30. <para>
  31. <command>prependName($keyValue, $content, $conditionalName)</command>
  32. </para>
  33. </listitem>
  34. <listitem>
  35. <para>
  36. <command>setName($keyValue, $content, $modifiers)</command>
  37. </para>
  38. </listitem>
  39. <listitem>
  40. <para>
  41. <command>appendHttpEquiv($keyValue, $content, $conditionalHttpEquiv)</command>
  42. </para>
  43. </listitem>
  44. <listitem>
  45. <para>
  46. <command>offsetSetHttpEquiv($index, $keyValue, $content, $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. XHTML1_RDFA doctype では、<link
  62. linkend="zend.view.helpers.initial.doctype">Doctype ヘルパー</link>
  63. で設定される以下のメソッドもサポートされます。
  64. </para>
  65. <itemizedlist>
  66. <listitem>
  67. <para>
  68. <command>appendProperty($property, $content, $modifiers)</command>
  69. </para>
  70. </listitem>
  71. <listitem>
  72. <para>
  73. <command>offsetSetProperty($index, $property, $content, $modifiers)</command>
  74. </para>
  75. </listitem>
  76. <listitem>
  77. <para>
  78. <command>prependProperty($property, $content, $modifiers)</command>
  79. </para>
  80. </listitem>
  81. <listitem>
  82. <para>
  83. <command>setProperty($property, $content, $modifiers)</command>
  84. </para>
  85. </listitem>
  86. </itemizedlist>
  87. <para>
  88. <varname>$keyValue</varname> は 'name' あるいは 'http-equiv'
  89. キーの値を定義します。<varname>$content</varname> は
  90. 'content' キーの値を定義し、<varname>$modifiers</varname>
  91. はオプションで連想配列を指定します。この配列には
  92. 'lang' や 'scheme' といったキーが含まれます。
  93. </para>
  94. <para>
  95. ヘルパーメソッド <methodname>headMeta()</methodname> で meta タグを設定することもできます。
  96. このメソッドのシグネチャは <command>headMeta($content,
  97. $keyValue, $keyType = 'name', $modifiers = array(), $placement =
  98. 'APPEND')</command>
  99. です。<varname>$keyValue</varname> には、
  100. <varname>$keyType</varname> ('name' あるいは 'http-equiv')
  101. で指定したキーのコンテンツを指定します。
  102. もし doctype が XHTML1_RDFA に設定されていたら、<varname>$keyType</varname>
  103. は 'property' としても指定されるかもしれません。
  104. <varname>$placement</varname> は 'SET' (既存の値をすべて上書きする)
  105. か 'APPEND' (スタックの最後に追加する)、
  106. あるいは 'PREPEND' (スタックの先頭に追加する) となります。
  107. </para>
  108. <para>
  109. <classname>HeadMeta</classname> は <methodname>append()</methodname> や
  110. <methodname>offsetSet()</methodname>、<methodname>prepend()</methodname>、そして <methodname>set()</methodname>
  111. をそれぞれオーバーライドして、上にあげた特別なメソッドを使用させるようにします。
  112. 内部的には、各項目を <property>stdClass</property> のトークンとして保管し、
  113. あとで <methodname>itemToString()</methodname> メソッドでシリアライズします。
  114. これはスタック内の項目についてチェックを行い、
  115. オプションでそれを修正したものを返します。
  116. </para>
  117. <para>
  118. <classname>HeadMeta</classname> ヘルパーは、
  119. <link linkend="zend.view.helpers.initial.placeholder">Placeholder
  120. ヘルパー</link> の具象実装です。
  121. </para>
  122. <example id="zend.view.helpers.initial.headmeta.basicusage">
  123. <title>HeadMeta ヘルパーの基本的な使用法</title>
  124. <para>
  125. meta タグは、いつでも好きなときに指定できます。
  126. 一般的には、クライアント側でのキャッシュの制御方法や
  127. SEO 用キーワードなどを指定します。
  128. </para>
  129. <para>
  130. たとえば、SEO 用のキーワードを指定したい場合は
  131. 'keywords' という名前の meta タグを作成します。
  132. そして、そのページに関連するキーワードを値として指定します。
  133. </para>
  134. <programlisting language="php"><![CDATA[
  135. // meta タグでキーワードを指定します
  136. $this->headMeta()->appendName('keywords', 'framework, PHP, productivity');
  137. ]]></programlisting>
  138. <para>
  139. クライアント側でのキャッシュの制御方法を指定したい場合は、
  140. http-equiv タグを設定してルールを指定します。
  141. </para>
  142. <programlisting language="php"><![CDATA[
  143. // クライアント側でのキャッシュを無効にします
  144. $this->headMeta()->appendHttpEquiv('expires',
  145. 'Wed, 26 Feb 1997 08:21:57 GMT')
  146. ->appendHttpEquiv('pragma', 'no-cache')
  147. ->appendHttpEquiv('Cache-Control', 'no-cache');
  148. ]]></programlisting>
  149. <para>
  150. meta タグの使い方としてもうひとつよくあるのは、
  151. コンテンツタイプや文字セット、言語を指定するものです。
  152. </para>
  153. <programlisting language="php"><![CDATA[
  154. // コンテンツタイプと文字セットを設定します
  155. $this->headMeta()->appendHttpEquiv('Content-Type',
  156. 'text/html; charset=UTF-8')
  157. ->appendHttpEquiv('Content-Language', 'en-US');
  158. ]]></programlisting>
  159. <para>
  160. もし <acronym>HTML</acronym>5 文書を提供しているなら、
  161. このように文字セットを提示すべきです。:
  162. </para>
  163. <programlisting language="php"><![CDATA[
  164. // HTML5 で文字セットを設定します
  165. $this->headMeta()->setCharset('UTF-8'); // <meta charset="UTF-8"> のように見えます
  166. ]]></programlisting>
  167. <para>
  168. 最後の例として、リダイレクトの前に見せるメッセージを
  169. "meta refresh" で指定するものを示します。
  170. </para>
  171. <programlisting language="php"><![CDATA[
  172. // 3 秒後に新しい URL に移動させます
  173. $this->headMeta()->appendHttpEquiv('Refresh',
  174. '3;URL=http://www.some.org/some.html');
  175. ]]></programlisting>
  176. <para>
  177. レイアウト内で meta タグを指定し終えたら、ヘルパーの内容を出力します。
  178. </para>
  179. <programlisting language="php"><![CDATA[
  180. <?php echo $this->headMeta() ?>
  181. ]]></programlisting>
  182. </example>
  183. <example id="zend.view.helpers.initial.headmeta.property">
  184. <title>XHTML1_RDFA doctype を用いた HeadMeta 使用法</title>
  185. <para>
  186. <link linkend="zend.view.helpers.initial.doctype">Doctype ヘルパー</link>
  187. で RDFa doctype を有功にすると、標準的な 'name' や 'http-equiv' に加えて、
  188. HeadMeta で 'property' 属性が使えるようになります。
  189. これは Facebook の <ulink url="http://opengraphprotocol.org/">Open Graph プロトコル</ulink>
  190. で一般的に用いられます。
  191. </para>
  192. <para>
  193. 例えば、Open Graph ページのタイトルと型を以下のように指定するかもしれません。
  194. </para>
  195. <programlisting language="php"><![CDATA[
  196. $this->doctype(Zend_View_Helper_Doctype::XHTML1_RDFA);
  197. $this->headMeta()->setProperty('og:title', 'my article title');
  198. $this->headMeta()->setProperty('og:type', 'article');
  199. echo $this->headMeta();
  200. //出力です。
  201. // <meta property="og:title" content="my article title" />
  202. // <meta property="og:type" content="article" />
  203. ]]></programlisting>
  204. </example>
  205. </sect3>
  206. <!--
  207. vim:se ts=4 sw=4 et:
  208. -->