Zend_View-Helpers-HeadStyle.xml 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- Reviewed: no -->
  3. <!-- EN-Revision: 14978 -->
  4. <sect3 id="zend.view.helpers.initial.headstyle">
  5. <title>HeadStyle ヘルパー</title>
  6. <para>
  7. HTML の <code>&lt;style&gt;</code> 要素を使用して、
  8. CSS スタイルシートを HTML の <code>&lt;head&gt;</code>
  9. 要素に埋め込みます。
  10. </para>
  11. <note>
  12. <title>HeadLink を使用した CSS ファイルへのリンク</title>
  13. <para>
  14. 外部スタイルシートの読み込み用の
  15. <code>&lt;link&gt;</code> 要素を作成する場合は
  16. <link linkend="zend.view.helpers.initial.headlink">HeadLink</link>
  17. を使用する必要があります。スタイルシートをインラインで定義したい場合に
  18. <code>HeadScript</code> を使用します。
  19. </para>
  20. </note>
  21. <para>
  22. <code>HeadStyle</code> ヘルパーがサポートするメソッドは次のとおりです。
  23. これらによってスタイルシート宣言の設定や追加を行います。
  24. </para>
  25. <itemizedlist>
  26. <listitem><para><code>appendStyle($content, $attributes =
  27. array())</code></para></listitem>
  28. <listitem><para><code>offsetSetStyle($index, $content, $attributes =
  29. array())</code></para></listitem>
  30. <listitem><para><code>prependStyle($content, $attributes =
  31. array())</code></para></listitem>
  32. <listitem><para><code>setStyle($content, $attributes =
  33. array())</code></para></listitem>
  34. </itemizedlist>
  35. <para>
  36. すべての場合において、<code>$content</code> には実際の CSS 宣言を指定します。
  37. <code>$attributes</code> には、<code>style</code> タグに追加したい属性があれば指定します。
  38. lang、title、media そして dir のすべてが使用可能です。
  39. </para>
  40. <note>
  41. <title>条件コメントの設定</title>
  42. <para>
  43. <code>HeadStyle</code> では、script タグを条件コメントで囲むことができます。
  44. そうすれば、特定のブラウザでだけスクリプトを実行しないこともできます。
  45. これを使用するには conditional タグを設定し、条件をメソッドコール時の
  46. <code>$attributes</code> パラメータで渡します。
  47. </para>
  48. <example id="zend.view.helpers.initial.headstyle.conditional">
  49. <title>Headstyle で条件コメントを使う例</title>
  50. <programlisting role="php"><![CDATA[
  51. // スクリプトを追加します
  52. $this->headStyle()->appendStyle($styles, array('conditional' => 'lt IE 7');
  53. ]]>
  54. </programlisting>
  55. </example>
  56. </note>
  57. <para>
  58. <code>HeadStyle</code> はスタイル宣言のキャプチャも行います。
  59. これは、宣言をプログラム上で作成してからどこか別の場所で使いたい場合に便利です。
  60. 使用法は、以下の例で示します。
  61. </para>
  62. <para>
  63. <code>headStyle()</code> メソッドを使うと、宣言の要素を手っ取り早く追加することができます。
  64. シグネチャは
  65. <code>headStyle($content$placement = 'APPEND', $attributes = array())</code>
  66. です。<code>$placement</code> には 'APPEND'、'PREPEND' あるいは 'SET'
  67. のいずれかを指定します。
  68. </para>
  69. <para>
  70. <code>HeadStyle</code> は <code>append()</code> や
  71. <code>offsetSet()</code>、<code>prepend()</code>、そして <code>set()</code>
  72. をそれぞれオーバーライドして、上にあげた特別なメソッドを使用させるようにします。
  73. 内部的には、各項目を <code>stdClass</code> のトークンとして保管し、
  74. あとで <code>itemToString()</code> メソッドでシリアライズします。
  75. これはスタック内の項目についてチェックを行い、
  76. オプションでそれを修正したものを返します。
  77. </para>
  78. <para>
  79. <code>HeadStyle</code> ヘルパーは、
  80. <link linkend="zend.view.helpers.initial.placeholder">Placeholder
  81. ヘルパー</link> の具象実装です。
  82. </para>
  83. <example id="zend.view.helpers.initial.headstyle.basicusage">
  84. <title>HeadStyle ヘルパーの基本的な使用法</title>
  85. <para>
  86. 新しい style タグを、好きなときに指定することができます。
  87. </para>
  88. <programlisting role="php"><![CDATA[
  89. // スタイルを追加します
  90. $this->headStyle()->appendStyle($styles);
  91. ]]>
  92. </programlisting>
  93. <para>
  94. CSS では並び順が重要となります。
  95. 指定した並び順で出力させる必要が出てくることでしょう。
  96. そのために使用するのが、append、prepend そして offsetSet
  97. といったディレクティブです。
  98. </para>
  99. <programlisting role="php"><![CDATA[
  100. // スタイルの順番を指定します
  101. // 特定の位置に置きます
  102. $this->headStyle()->offsetSetStyle(100, $customStyles);
  103. // 最後に置きます
  104. $this->headStyle()->appendStyle($finalStyles);
  105. // 先頭に置きます
  106. $this->headStyle()->prependStyle($firstStyles);
  107. ]]>
  108. </programlisting>
  109. <para>
  110. すべてのスタイル宣言を出力する準備が整ったら、
  111. あとはレイアウトスクリプトでそれを出力するだけです。
  112. </para>
  113. <programlisting role="php"><![CDATA[
  114. <?php echo $this->headStyle() ?>
  115. ]]>
  116. </programlisting>
  117. </example>
  118. <example id="zend.view.helpers.initial.headstyle.capture">
  119. <title>HeadStyle ヘルパーによるスタイル宣言のキャプチャ</title>
  120. <para>
  121. 時には CSS のスタイル宣言をプログラムで生成しなければならないこともあるでしょう。
  122. 文字列の連結やヒアドキュメント等を使っても構いませんが、
  123. ふつうにスタイルを作成してそれを PHP のタグに埋め込めればより簡単です。
  124. <code>HeadStyle</code> は、スタックにキャプチャすることでこれを実現します。
  125. </para>
  126. <programlisting role="php"><![CDATA[
  127. <?php $this->headStyle()->captureStart() ?>
  128. body {
  129. background-color: <?php echo $this->bgColor ?>;
  130. }
  131. <?php $this->headStyle()->captureEnd() ?>
  132. ]]>
  133. </programlisting>
  134. <para>
  135. 前提条件は次のとおりです。
  136. </para>
  137. <itemizedlist>
  138. <listitem><para>
  139. スタイル宣言は、スタックの末尾に追加されていきます。
  140. 既存のスタックを上書きしたりスタックの先頭に追加したりしたい場合は、
  141. それぞれ 'SET' あるいは 'PREPEND' を
  142. <code>captureStart()</code> の最初の引数として渡します。
  143. </para></listitem>
  144. <listitem><para>
  145. <code>&lt;style&gt;</code> タグに追加の属性を指定したい場合は、
  146. <code>captureStart()</code> の 2 番目の引数に配列形式で渡します。
  147. </para></listitem>
  148. </itemizedlist>
  149. </example>
  150. </sect3>
  151. <!--
  152. vim:se ts=4 sw=4 et:
  153. -->