Zend_View-Helpers-HeadStyle.xml 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 24604 -->
  4. <sect3 id="zend.view.helpers.initial.headstyle">
  5. <title>HeadStyle ヘルパー</title>
  6. <para>
  7. <acronym>HTML</acronym> の <emphasis>&lt;style&gt;</emphasis> 要素を使用して、
  8. <acronym>CSS</acronym> スタイルシートを <acronym>HTML</acronym> の <emphasis>&lt;head&gt;</emphasis>
  9. 要素に埋め込みます。
  10. </para>
  11. <note>
  12. <title>HeadLink を使用した <acronym>CSS</acronym> ファイルへのリンク</title>
  13. <para>
  14. 外部スタイルシートの読み込み用の
  15. <emphasis>&lt;link&gt;</emphasis> 要素を作成する場合は
  16. <link linkend="zend.view.helpers.initial.headlink">HeadLink</link>
  17. を使用する必要があります。スタイルシートをインラインで定義したい場合に
  18. <classname>HeadStyle</classname> を使用します。
  19. </para>
  20. </note>
  21. <para>
  22. <classname>HeadStyle</classname> ヘルパーがサポートするメソッドは次のとおりです。
  23. これらによってスタイルシート宣言の設定や追加を行います。
  24. </para>
  25. <itemizedlist>
  26. <listitem>
  27. <para>
  28. <command>appendStyle($content, $attributes = array())</command>
  29. </para>
  30. </listitem>
  31. <listitem>
  32. <para>
  33. <command>offsetSetStyle($index, $content, $attributes = array())</command>
  34. </para>
  35. </listitem>
  36. <listitem>
  37. <para>
  38. <command>prependStyle($content, $attributes = array())</command>
  39. </para>
  40. </listitem>
  41. <listitem>
  42. <para>
  43. <command>setStyle($content, $attributes = array())</command>
  44. </para>
  45. </listitem>
  46. </itemizedlist>
  47. <para>
  48. すべての場合において、<varname>$content</varname> には実際の <acronym>CSS</acronym> 宣言を指定します。
  49. <varname>$attributes</varname> には、<property>style</property> タグに追加したい属性があれば指定します。
  50. lang、title、media そして dir のすべてが使用可能です。
  51. </para>
  52. <note>
  53. <title>条件コメントの設定</title>
  54. <para>
  55. <classname>HeadStyle</classname> では、script タグを条件コメントで囲むことができます。
  56. そうすれば、特定のブラウザでだけスクリプトを実行しないこともできます。
  57. これを使用するには conditional タグを設定し、条件をメソッドコール時の
  58. <varname>$attributes</varname> パラメータで渡します。
  59. </para>
  60. <example id="zend.view.helpers.initial.headstyle.conditional">
  61. <title>Headstyle で条件コメントを使う例</title>
  62. <programlisting language="php"><![CDATA[
  63. // スクリプトを追加します
  64. $this->headStyle()->appendStyle($styles, array('conditional' => 'lt IE 7'));
  65. ]]></programlisting>
  66. </example>
  67. </note>
  68. <para>
  69. <classname>HeadStyle</classname> はスタイル宣言のキャプチャも行います。
  70. これは、宣言をプログラム上で作成してからどこか別の場所で使いたい場合に便利です。
  71. 使用法は、以下の例で示します。
  72. </para>
  73. <para>
  74. <methodname>headStyle()</methodname> メソッドを使うと、宣言の要素を手っ取り早く追加できます。
  75. シグネチャは
  76. <methodname>headStyle($content$placement = 'APPEND', $attributes = array())</methodname>
  77. です。<varname>$placement</varname> には 'APPEND'、'PREPEND' あるいは 'SET'
  78. のいずれかを指定します。
  79. </para>
  80. <para>
  81. <classname>HeadStyle</classname> は <methodname>append()</methodname> や
  82. <methodname>offsetSet()</methodname>、<methodname>prepend()</methodname>、そして <methodname>set()</methodname>
  83. をそれぞれオーバーライドして、上にあげた特別なメソッドを使用させるようにします。
  84. 内部的には、各項目を <property>stdClass</property> のトークンとして保管し、
  85. あとで <methodname>itemToString()</methodname> メソッドでシリアライズします。
  86. これはスタック内の項目についてチェックを行い、
  87. オプションでそれを修正したものを返します。
  88. </para>
  89. <para>
  90. <classname>HeadStyle</classname> ヘルパーは、
  91. <link linkend="zend.view.helpers.initial.placeholder">Placeholder
  92. ヘルパー</link> の具象実装です。
  93. </para>
  94. <note>
  95. <title>デフォルトで使用される UTF-8 エンコーディング</title>
  96. <!-- TODO : to be translated -->
  97. <para>
  98. By default, Zend Framework uses <acronym>UTF-8</acronym> as its default encoding, and,
  99. specific to this case, <classname>Zend_View</classname> does as well. Character encoding
  100. can be set differently on the view object itself using the
  101. <methodname>setEncoding()</methodname> method (or the <varname>encoding</varname>
  102. instantiation parameter). However, since <classname>Zend_View_Interface</classname> does
  103. not define accessors for encoding, it's possible that if you are using a custom view
  104. implementation with this view helper, you will not have a
  105. <methodname>getEncoding()</methodname> method, which is what the view helper uses
  106. internally for determining the character set in which to encode.
  107. </para>
  108. <para>
  109. If you do not want to utilize <acronym>UTF-8</acronym> in such a situation, you will
  110. need to implement a <methodname>getEncoding()</methodname> method in your custom view
  111. implementation.
  112. </para>
  113. </note>
  114. <example id="zend.view.helpers.initial.headstyle.basicusage">
  115. <title>HeadStyle ヘルパーの基本的な使用法</title>
  116. <para>
  117. 新しい style タグを、好きなときに指定できます。
  118. </para>
  119. <programlisting language="php"><![CDATA[
  120. // スタイルを追加します
  121. $this->headStyle()->appendStyle($styles);
  122. ]]></programlisting>
  123. <para>
  124. <acronym>CSS</acronym> では並び順が重要となります。
  125. 指定した並び順で出力させる必要が出てくることでしょう。
  126. そのために使用するのが、append、prepend そして offsetSet
  127. といったディレクティブです。
  128. </para>
  129. <programlisting language="php"><![CDATA[
  130. // スタイルの順番を指定します
  131. // 特定の位置に置きます
  132. $this->headStyle()->offsetSetStyle(100, $customStyles);
  133. // 最後に置きます
  134. $this->headStyle()->appendStyle($finalStyles);
  135. // 先頭に置きます
  136. $this->headStyle()->prependStyle($firstStyles);
  137. ]]></programlisting>
  138. <para>
  139. すべてのスタイル宣言を出力する準備が整ったら、
  140. あとはレイアウトスクリプトでそれを出力するだけです。
  141. </para>
  142. <programlisting language="php"><![CDATA[
  143. <?php echo $this->headStyle() ?>
  144. ]]></programlisting>
  145. </example>
  146. <example id="zend.view.helpers.initial.headstyle.capture">
  147. <title>HeadStyle ヘルパーによるスタイル宣言のキャプチャ</title>
  148. <para>
  149. 時には <acronym>CSS</acronym> のスタイル宣言をプログラムで生成しなければならないこともあるでしょう。
  150. 文字列の連結やヒアドキュメント等を使っても構いませんが、
  151. ふつうにスタイルを作成してそれを <acronym>PHP</acronym> のタグに埋め込めればより簡単です。
  152. <classname>HeadStyle</classname> は、スタックにキャプチャすることでこれを実現します。
  153. </para>
  154. <programlisting language="php"><![CDATA[
  155. <?php $this->headStyle()->captureStart() ?>
  156. body {
  157. background-color: <?php echo $this->bgColor ?>;
  158. }
  159. <?php $this->headStyle()->captureEnd() ?>
  160. ]]></programlisting>
  161. <para>
  162. 前提条件は次のとおりです。
  163. </para>
  164. <itemizedlist>
  165. <listitem>
  166. <para>
  167. スタイル宣言は、スタックの末尾に追加されていきます。
  168. 既存のスタックを上書きしたりスタックの先頭に追加したりしたい場合は、
  169. それぞれ 'SET' あるいは 'PREPEND' を
  170. <methodname>captureStart()</methodname> の最初の引数として渡します。
  171. </para>
  172. </listitem>
  173. <listitem>
  174. <para>
  175. <emphasis>&lt;style&gt;</emphasis> タグに追加の属性を指定したい場合は、
  176. <methodname>captureStart()</methodname> の 2 番目の引数に配列形式で渡します。
  177. </para>
  178. </listitem>
  179. </itemizedlist>
  180. </example>
  181. </sect3>
  182. <!--
  183. vim:se ts=4 sw=4 et:
  184. -->