Zend_View-Helpers-HeadStyle.xml 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.view.helpers.initial.headstyle">
  5. <title>HeadStyle Helfer</title>
  6. <para>
  7. Das <acronym>HTML</acronym> Element <emphasis>&lt;style&gt;</emphasis> wird verwendet um
  8. <acronym>CSS</acronym> Stylesheets im <acronym>HTML</acronym> Element
  9. <emphasis>&lt;head&gt;</emphasis> zu inkludieren.
  10. </para>
  11. <note>
  12. <title>HeadLink verwenden um CSS Dateien zu verlinken</title>
  13. <para>
  14. <link linkend="zend.view.helpers.initial.headlink">HeadLink</link> sollte verwendet
  15. werden um <emphasis>&lt;link&gt;</emphasis> Elemente zu Erstellen die externe
  16. Stylesheets enthalten. <classname>HeadStyle</classname> wird verwendet wenn man
  17. Stylesheets inline definieren will.
  18. </para>
  19. </note>
  20. <para>
  21. Der <classname>HeadStyle</classname> Helfer unterstützt die folgenden Methoden für das
  22. Setzen und Hinzufügen von Stylesheet Deklarationen:
  23. </para>
  24. <itemizedlist>
  25. <listitem>
  26. <para>
  27. <command>appendStyle($content, $attributes = array())</command>
  28. </para>
  29. </listitem>
  30. <listitem>
  31. <para>
  32. <command>offsetSetStyle($index, $content, $attributes = array())</command>
  33. </para>
  34. </listitem>
  35. <listitem>
  36. <para>
  37. <command>prependStyle($content, $attributes = array())</command>
  38. </para>
  39. </listitem>
  40. <listitem>
  41. <para>
  42. <command>setStyle($content, $attributes = array())</command>
  43. </para>
  44. </listitem>
  45. </itemizedlist>
  46. <para>
  47. In allen Fällen ist <varname>$content</varname> die aktuelle <acronym>CSS</acronym>
  48. Deklaration. <varname>$attributes</varname> sind alle zusätzlichen Attribute die das
  49. <property>style</property> Tag erhalten soll: lang, title, media, oder dir sind alle
  50. möglich.
  51. </para>
  52. <note>
  53. <title>Abhängige Kommentare setzen</title>
  54. <para>
  55. <classname>HeadStyle</classname> erlaubt es ein Script Tag in abhängige Kommentare zu
  56. setzen, das es erlaubt es vor speziellen Browsern zu verstecken. Um abhängige Tags zu
  57. setzen, muß der abhängige Wert als Teil des <varname>$attrs</varname> Parameters im
  58. Methodenaufruf übergeben werden.
  59. </para>
  60. <example id="zend.view.helpers.initial.headstyle.conditional">
  61. <title>Headstyle mit abhängigen Kommentaren</title>
  62. <programlisting language="php"><![CDATA[
  63. // Skripte hinzufügen
  64. $this->headStyle()->appendStyle($styles, array('conditional' => 'lt IE 7'));
  65. ]]></programlisting>
  66. </example>
  67. </note>
  68. <para>
  69. <classname>HeadStyle</classname> erlaubt auch das Erfassen von Style Deklarationen; das kann
  70. nützlich sein wenn eine Deklaration programmtechnisch erstellt werden soll und Sie dann
  71. woanders platziert wird. Die Verwendung hierfür wird in einem unten angeführten Beispiel
  72. gezeigt.
  73. </para>
  74. <para>
  75. Letztendlich kann auch die <methodname>headStyle()</methodname> Methode verwendet werden um
  76. schnellstens Deklarationselemente hinzuzufügen; die Signatur dafür ist
  77. <methodname>headStyle($content$placement = 'APPEND', $attributes = array())</methodname>.
  78. <varname>$placement</varname> sollte entweder 'APPEND', 'PREPEND', oder 'SET' sein.
  79. </para>
  80. <para>
  81. <classname>HeadStyle</classname> überschreibt jedes <methodname>append()</methodname>,
  82. <methodname>offsetSet()</methodname>, <methodname>prepend()</methodname>, und
  83. <methodname>set()</methodname> um die Verwendung der oben gelisteten speziellen Methoden zu
  84. forcieren. Intern wird jeder Teil als <property>stdClass</property> Token gespeichert,
  85. welches später serialisiert wird durch Verwendung der
  86. <methodname>itemToString()</methodname> Methode. Das erlaubt es die Teile im Stack zu
  87. Prüfen, und optional auch zu Ändern durch einfaches Modifizieren des zurückgegebenen
  88. Objektes.
  89. </para>
  90. <para>
  91. Der <classname>HeadStyle</classname> Helfer ist eine konkrete Implementation des
  92. <link linkend="zend.view.helpers.initial.placeholder">Platzhalter Helfers</link>.
  93. </para>
  94. <note>
  95. <title>Standardmäßig wird die UTF-8 Kodierung verwendet</title>
  96. <para>
  97. Standardmäßig verwendet Zend Framework <acronym>UTF-8</acronym> als seine
  98. Standardkodierung, und speziell in diesem Fall, macht das
  99. <classname>Zend_View</classname> genauso. Die Zeichenkodierung kann im View Objekt
  100. selbst auf etwas anderes gesetzt werden indem die Methode
  101. <methodname>setEncoding()</methodname> verwendet wird (oder der Parameter
  102. <varname>encoding</varname> bei der Instanzierung angegeben wird). Trotzdem, da
  103. <classname>Zend_View_Interface</classname> keine Zugriffsmethoden für die Kodierung
  104. anbietet ist es möglich dass, wenn man eine eigene View Implementation verwendet, man
  105. keine <methodname>getEncoding()</methodname> Methode hat, welche der View Helfer intern
  106. für die Erkennung des Zeichensets verwendet in das kodiert werden soll.
  107. </para>
  108. <para>
  109. Wenn man <acronym>UTF-8</acronym> in solch einer Situation nicht verwenden will, muss
  110. man in der eigenen View Implementation eine <methodname>getEncoding()</methodname>
  111. Methode implementieren.
  112. </para>
  113. </note>
  114. <example id="zend.view.helpers.initial.headstyle.basicusage">
  115. <title>Grundsätzliche Verwendung des HeadStyle Helfers</title>
  116. <para>
  117. Ein neues Style Tag kann jederzeit spezifiziert werden:
  118. </para>
  119. <programlisting language="php"><![CDATA[
  120. // Stile hinzufügen
  121. $this->headStyle()->appendStyle($styles);
  122. ]]></programlisting>
  123. <para>
  124. Die Reihenfolge ist in <acronym>CSS</acronym> sehr wichtig; es könnte sein das man
  125. sichergestellen muß das Deklarationen in einer speziellen Reihenfolge geladen werden
  126. wegen der Reihenfolge der Kaskade; die verschiedenen append, prepend und offsetSet
  127. Direktiven können für diesen Zweck verwendet werden:
  128. </para>
  129. <programlisting language="php"><![CDATA[
  130. // Styles in Reihenfolge bringen
  131. // Ein spezielles Offset platzieren:
  132. $this->headStyle()->offsetSetStyle(100, $customStyles);
  133. // Am Ende platzieren:
  134. $this->headStyle()->appendStyle($finalStyles);
  135. // Am Anfang platzieren:
  136. $this->headStyle()->prependStyle($firstStyles);
  137. ]]></programlisting>
  138. <para>
  139. Wenn man damit fertig ist und alle Style Deklarationen im Layout Skript ausgegeben
  140. werden können kann der Helfer einfach wiederholt werden:
  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>Den HeadStyle Helfer verwenden um Style Deklarationen zu Erfassen</title>
  148. <para>
  149. Hier und da müssen <acronym>CSS</acronym> Style Deklarationen programmtechnisch erstellt
  150. werden. Wärend String Kopplungen, HereDocs und ähnliches verwendet werden könnte, ist es
  151. oft einfacher das durch erstellen der Styles und deren Einfügung in
  152. <acronym>PHP</acronym> Tags zu machen. <classname>HeadStyle</classname> lässt das zu
  153. indem es in den Stack erfasst wird:
  154. </para>
  155. <programlisting language="php"><![CDATA[
  156. <?php $this->headStyle()->captureStart() ?>
  157. body {
  158. background-color: <?php echo $this->bgColor ?>;
  159. }
  160. <?php $this->headStyle()->captureEnd() ?>
  161. ]]></programlisting>
  162. <para>
  163. Die folgenden Annahmen werden gemacht:
  164. </para>
  165. <itemizedlist>
  166. <listitem>
  167. <para>
  168. Die Style Deklarationen werden dem Stack angefügt. Wenn Sie den Stack ersetzen
  169. sollen oder an den Anfang hinzugefügt werden sollten muß 'SET' oder 'PREPEND'
  170. als erstes Argument an <methodname>captureStart()</methodname> übergeben werden
  171. </para>
  172. </listitem>
  173. <listitem>
  174. <para>
  175. Wenn zusätzliche Attribute für das <emphasis>&lt;style&gt;</emphasis> Tag
  176. spezifiziert werden sollen, dann müssen diese in einem Array als zweites
  177. Argument an <methodname>captureStart()</methodname> übergeben werden.
  178. </para>
  179. </listitem>
  180. </itemizedlist>
  181. </example>
  182. </sect3>