view-placeholders-standard.xml 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 20109 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="learning.view.placeholders.standard">
  5. <title>Standard Platzhalter</title>
  6. <para>
  7. In der <link linkend="learning.view.placeholders.basics">voerherigen Sektion</link>, haben
  8. wir den <methodname>placeholder()</methodname> View Helfer kennengelernt, und wie er für das
  9. Sammeln eigener Inhalte verwendet werden kann. In dieser Sektion sehen wir uns einige
  10. konkrete Platzhalter an die mit Zend Framework ausgeliefert werden, und wie Sie für den
  11. eigenen Vorteil verwendet werden können wenn komplexe kombinierte Layouts erstellt werden.
  12. </para>
  13. <para>
  14. Die meisten mitgelieferten Platzhalter sind für die Erstellung von Inhalten der
  15. <code>&lt;head&gt;</code> Sektion des Layout Inhalts -- ein Areal das man normalerweise
  16. nicht direkt über Anwendungs View Skripte manipuliert, aber eines das man beeinflussen will.
  17. Als Beispiel: Wenn man will das der Titel auf jeder Seite bestimmte Inhalte enthält, aber
  18. spezifische Inhalte auf dem Controller und/oder der Aktion basieren; wenn man
  19. <acronym>CSS</acronym> Dateien spezifizieren will um Sie basieren auf der Sektion in der man
  20. sich befindet zu Laden; wenn man spezifische JavaScript Skripts zu unterschiedlichen Zeiten
  21. laden will; oder wenn man die <acronym>DocType</acronym> Deklaration setzen will.
  22. </para>
  23. <para>
  24. Zend Framework wird mit einer Platzhalter Implementation für jede dieser Situationen
  25. ausgeliefert, und verschiedenen mehr.
  26. </para>
  27. <sect2 id="learning.view.placeholders.standard.doctype">
  28. <title>Setzen vom DocType</title>
  29. <para>
  30. Die <acronym>DocType</acronym> Deklaration ist problematisch zu merken, und oft ist es
  31. essentiell Sie in die Dokumente einzubinden um sicherzustellen das der Browser den
  32. Inhalt richtig darstellt. Der <methodname>doctype()</methodname> View Helfer erlaubt es
  33. einfache String Merkmale zu verwenden um den gewünschten <acronym>DocType</acronym> zu
  34. spezifizieren; zusätzlich fragen andere Helfer den <methodname>doctype()</methodname>
  35. ab, um sicherzustellen dass die erzeugte Ausgabe mit dem angefragten
  36. <acronym>DocType</acronym> übereinstimmt.
  37. </para>
  38. <para>
  39. Wenn man als Beispiel <acronym>XHTML1</acronym> Strict <acronym>DTD</acronym> verwenden
  40. will kann man einfach folgendes spezifizieren:
  41. </para>
  42. <programlisting language="php"><![CDATA[
  43. $this->doctype('XHTML1_STRICT');
  44. ]]></programlisting>
  45. <para>
  46. Neben anderen vorhandenen Gedächnishilfen sind die folgenden Typen zu finden:
  47. </para>
  48. <variablelist>
  49. <varlistentry>
  50. <term>XHTML1_STRICT</term>
  51. <listitem>
  52. <para>
  53. <acronym>XHTML</acronym> 1.0 Strict
  54. </para>
  55. </listitem>
  56. </varlistentry>
  57. <varlistentry>
  58. <term>XHTML1_TRANSITIONAL</term>
  59. <listitem>
  60. <para>
  61. <acronym>XHTML</acronym> 1.0 Transitional
  62. </para>
  63. </listitem>
  64. </varlistentry>
  65. <varlistentry>
  66. <term>HTML4_STRICT</term>
  67. <listitem>
  68. <para>
  69. <acronym>HTML</acronym> 4.01 Strict
  70. </para>
  71. </listitem>
  72. </varlistentry>
  73. <varlistentry>
  74. <term>HTML4_Loose</term>
  75. <listitem>
  76. <para>
  77. <acronym>HTML</acronym> 4.01 Loose
  78. </para>
  79. </listitem>
  80. </varlistentry>
  81. <varlistentry>
  82. <term>HTML5</term>
  83. <listitem>
  84. <para>
  85. <acronym>HTML</acronym> 5
  86. </para>
  87. </listitem>
  88. </varlistentry>
  89. </variablelist>
  90. <para>
  91. Man kann den Typ zuordnen und die Deklaration in einem einzelnen Aufruf darstellen:
  92. </para>
  93. <programlisting language="php"><![CDATA[
  94. echo $this->doctype('XHTML1_STRICT');
  95. ]]></programlisting>
  96. <para>
  97. Trotzdem ist der bessere Ansatz den Typ in der Bootstrap zuzuordnen, und Ihn dann im
  98. Layout darzustellen. Man könnte versuchen das folgende in der Bootstrap Klasse
  99. hinzuzufügen:
  100. </para>
  101. <programlisting language="php"><![CDATA[
  102. class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
  103. {
  104. protected function _initDocType()
  105. {
  106. $this->bootstrap('View');
  107. $view = $this->getResource('View');
  108. $view->doctype('XHTML1_STRICT');
  109. }
  110. }
  111. ]]></programlisting>
  112. <para>
  113. Und dann im Layout Skript einfach auf dem Helfer am Beginn der Datei
  114. <function>echo</function> ausrufen:
  115. </para>
  116. <programlisting language="php"><![CDATA[
  117. <?php echo $this->doctype() ?>
  118. <html>
  119. <!-- ... -->
  120. ]]></programlisting>
  121. <para>
  122. Das stellt sicher dass DocType-beachtende View Helfer das richtige Markup darstellen,
  123. das der Typ richtig gesetzt ist bevor das Layout dargestellt wird, und bietet einen
  124. einzelnen Ort an dem der DocType geändert werden kann.
  125. </para>
  126. </sect2>
  127. <sect2 id="learning.view.placeholders.standard.head-title">
  128. <title>Den Titel der Seite spezifizieren</title>
  129. <para>
  130. Oft will eine Site den Namen der Site oder der Firma als Teil des Seitentitels einfügen,
  131. und dann zusätzliche Informationen basieren auf dem Ort in dieser Site einfügen. Als
  132. Beispiel enthält die Website zend.com den String "Zend.com" auf allen Seiten und fügt
  133. Informationen basierend auf der Seite voran: "Zend Server - Zend.com". Im Zend Framework
  134. kann der <methodname>headTitle()</methodname> View Helfer helfen diese Aufgabe zu
  135. vereinfachen.
  136. </para>
  137. <para>
  138. Am einfachsten erlaubt es der <methodname>headTitle()</methodname> Helfer den Inhalt zu
  139. für das <code>&lt;title&gt;</code> Tag zu sammeln; wenn man es ausgibt, wird es
  140. basierend auf der Reihenfolge mit der es hinzugefügt wurde zusammengefügt. Man kann die
  141. Reihenfolge kontrollieren indem <methodname>prepend()</methodname> und
  142. <methodname>append()</methodname> verwendet werden, und einen Separator angegeben
  143. welcher zwischen den Segmenten zu verwenden ist, indem die Methode
  144. <methodname>setSeparator()</methodname> verwendet wird.
  145. </para>
  146. <para>
  147. Typischerweise sollten jene Segmente die in allen Seiten gemeinsam sind in der Bootstrap
  148. spezifiziert werden, ähnlich wie wir den DocType definiert haben. In diesem Fall
  149. definieren wir eine <methodname>_initPlaceholders()</methodname> Methode um auf den
  150. verschiedenen Platzhaltern zu arbeiten, und einen initialen Titel sowie einen Separator
  151. zu spezifizieren.
  152. </para>
  153. <programlisting language="php"><![CDATA[
  154. class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
  155. {
  156. // ...
  157. protected function _initPlaceholders()
  158. {
  159. $this->bootstrap('View');
  160. $view = $this->getResource('View');
  161. $view->doctype('XHTML1_STRICT');
  162. // Setzt den initialen Titel und Separator:
  163. $view->headTitle('Meine Site')
  164. ->setSeparator(' :: ');
  165. }
  166. // ...
  167. }
  168. ]]></programlisting>
  169. <para>
  170. Im View Skript könnten wir ein weiteres Segment hinzufügen:
  171. </para>
  172. <programlisting language="php"><![CDATA[
  173. <?php $this->headTitle()->append('Eine Seite'); // Nach anderen Segmenten platzieren ?>
  174. <?php $this->headTitle()->prepend('Eine Seite'); // Davor platzieren ?>
  175. ]]></programlisting>
  176. <para>
  177. In unserem Layout geben wie den <methodname>headTitle()</methodname> Helfer einfach aus:
  178. </para>
  179. <programlisting language="php"><![CDATA[
  180. <?php echo $this->doctype() ?>
  181. <html>
  182. <?php echo $this->headTitle() ?>
  183. <!-- ... -->
  184. ]]></programlisting>
  185. <para>
  186. Das erzeugt die folgende Ausgabe:
  187. </para>
  188. <programlisting language="html"><![CDATA[
  189. <!-- Wenn append() verwendet wurde: -->
  190. <title>Meine Site :: Eine Seite</title>
  191. <!-- Wenn prepend() verwendet wurde: -->
  192. <title>Eine Seite :: Meine Site</title>
  193. ]]></programlisting>
  194. </sect2>
  195. <sect2 id="learning.view.placeholders.standard.head-link">
  196. <title>Stylesheets mit HeadLink spezifizieren</title>
  197. <para>
  198. Gute <acronym>CSS</acronym> Entwickler erstellen oft ein generisches Stylesheet für
  199. Siteweite Stile, und individuelle Stylesheets für spezifische Sektionen oder Seite der
  200. Website, und laden die zweiteren über Konditionen um die Menge der Daten zu verringern
  201. die bei jeder Anfrage übertragen werden müssen. Der <methodname>headLink()</methodname>
  202. Platzhalter macht die Sammlung von solchen konditionellen Stylesheets in der Anwendung
  203. trivial.
  204. </para>
  205. <para>
  206. Um das zu ermöglichen definiert <methodname>headLink()</methodname> eine Anzahl von
  207. "virtuellen" Methoden (durch Überladen) welche den Prozess trivial machen. Jene mit
  208. denen wir uns befassen sind <methodname>appendStylesheet()</methodname> und
  209. <methodname>prependStylesheet()</methodname>. Jede nimmt bis zu vier Argumente,
  210. <varname>$href</varname> (den relativen Pfad zum Stylesheet), <varname>$media</varname>
  211. (den <acronym>MIME</acronym> Typ, der standardmäßig "text/css" ist),
  212. <varname>$conditionalStylesheet</varname> (kann verwendet werden um eine "Kondition" zu
  213. spezifizieren bei dem das Stylesheet evaluiert wird), und <varname>$extras</varname>
  214. (ein assoziatives Array von Schlüssel und Werte Paare, üblicherweise verwendet um einen
  215. Schlüssel für "media" zu definieren). In den meisten Fällen muss man nur das erste
  216. Argument spezifizieren, den relativen Pfad zum Stylesheet.
  217. </para>
  218. <para>
  219. In unserem Beispiel nehmen wir an das alle Seiten das Stylesheet laden mussen welches in
  220. "<filename>/styles/site.css</filename>" vorhanden ist (relativ zum Dokument Root); wir
  221. spezifizieren dass in unserer Bootstrap Methode
  222. <methodname>_initPlaceholders()</methodname>.
  223. </para>
  224. <programlisting language="php"><![CDATA[
  225. class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
  226. {
  227. // ...
  228. protected function _initPlaceholders()
  229. {
  230. $this->bootstrap('View');
  231. $view = $this->getResource('View');
  232. $view->doctype('XHTML1_STRICT');
  233. // Setzt den initialen Titel und Separator:
  234. $view->headTitle('Meine Site')
  235. ->setSeparator(' :: ');
  236. // Setzt das initiale Stylesheet:
  237. $view->headLink()->prependStylesheet('/styles/site.css');
  238. }
  239. // ...
  240. }
  241. ]]></programlisting>
  242. <para>
  243. Später, im Controller oder einem Action-spezifischen View Skript, können wir weitere
  244. Stylesheets hinzufügen:
  245. </para>
  246. <programlisting language="php"><![CDATA[
  247. <?php $this->headLink()->appendStylesheet('/styles/user-list.css') ?>
  248. ]]></programlisting>
  249. <para>
  250. In unserem Layout View Skript geben wir den Platzhalter einfach wieder aus:
  251. </para>
  252. <programlisting language="php"><![CDATA[
  253. <?php echo $this->doctype() ?>
  254. <html>
  255. <?php echo $this->headTitle() ?>
  256. <?php echo $this->headLink() ?>
  257. <!-- ... -->
  258. ]]></programlisting>
  259. <para>
  260. Das erzeugt die folgende Ausgabe:
  261. </para>
  262. <programlisting language="html"><![CDATA[
  263. <link rel="stylesheet" type="text/css" href="/styles/site.css" />
  264. <link rel="stylesheet" type="text/css" href="/styles/user-list.css" />
  265. ]]></programlisting>
  266. </sect2>
  267. <sect2 id="learning.view.placeholders.standard.head-script">
  268. <title>Sammeln von Skripten durch Verwendung von HeadScript</title>
  269. <para>
  270. Eine andere gemeinsame Taktik um lange Ladezeiten bei Seiten zu verhindern besteht darin
  271. JavaScript nur dann zu Laden wenn es notwendig ist. So gesehen benötigt man verschiedene
  272. Layer von Skripten: möglicherweise einen für die fortlaufende Verbesserung der Menüs der
  273. Site, und einen weiteren für Seiten-spezifische Inhalte. In diesen Situationen bietet
  274. der <methodname>headScript()</methodname> Helfer eine Lösung.
  275. </para>
  276. <para>
  277. Ähnlich wie der <methodname>headLink()</methodname> Helfer bietet
  278. <methodname>headScript()</methodname> die Möglichkeit Skripte der Sammlung anzuhängen
  279. oder voranzustellen, und dann das komplette Set auszugeben. Es bietet die Flexibilität
  280. Skriptdateien zu spezifizieren damit diese selbst geladen werden, als auch explizit
  281. JavaScript. Man hat auch die Option JavaScript über
  282. <methodname>captureStart()</methodname>/<methodname>captureEnd()</methodname>
  283. einzufangen, was es erlaubt JavaScript einfach im Code zu haben statt notwendigerweise
  284. einen zusätzlichen Aufruf zum Server zu machen.
  285. </para>
  286. <para>
  287. So wie <methodname>headLink()</methodname> bietet <methodname>headScript()</methodname>
  288. "virtuelle" Methoden durch Überladen als Bequemlichkeit wenn Elemente spezifiziert
  289. werden um Sie zu sammeln; übliche Methoden sind <methodname>prependFile()</methodname>,
  290. <methodname>appendFile()</methodname>, <methodname>prependScript()</methodname>, und
  291. <methodname>appendScript()</methodname>. Die ersten zwei erlauben es Dateien zu
  292. spezifizieren auf die im <varname>$src</varname> Attribut des
  293. <code>&lt;script&gt;</code> Tags referenziert wird; die letzteren zwei nehmen den
  294. angegebenen Inhalt und stellen Ihn als literales JavaScript im
  295. <code>&lt;script&gt;</code> Tag dar.
  296. </para>
  297. <para>
  298. In diesem Beispiel spezifizieren wir ein Skript, "<filename>/js/site.js</filename>"
  299. muss bei jeder Seite geladen werden; wir aktualisieren die
  300. <methodname>_initPlaceholders()</methodname> Methode in der Bootstrap um das zu tun.
  301. </para>
  302. <programlisting language="php"><![CDATA[
  303. class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
  304. {
  305. // ...
  306. protected function _initPlaceholders()
  307. {
  308. $this->bootstrap('View');
  309. $view = $this->getResource('View');
  310. $view->doctype('XHTML1_STRICT');
  311. // Setzt den initialen Titel und Separator:
  312. $view->headTitle('My Site')
  313. ->setSeparator(' :: ');
  314. // Setzt das initiale Stylesheet:
  315. $view->headLink()->prependStylesheet('/styles/site.css');
  316. // Setzt das initiale JS das geladen werden soll:
  317. $view->headScript()->prependFile('/js/site.js');
  318. }
  319. // ...
  320. }
  321. ]]></programlisting>
  322. <para>
  323. In einem View Skript können wir dann eine extra Skript Datei der Quelle hinzufügen um
  324. etwas JavaScript zu sammeln und es in unserem Dokument einzufügen.
  325. </para>
  326. <programlisting language="php"><![CDATA[
  327. <?php $this->headScript()->appendFile('/js/user-list.js') ?>
  328. <?php $this->headScript()->captureStart() ?>
  329. site = {
  330. baseUrl: "<?php echo $this->baseUrl() ?>"
  331. };
  332. <?php $this->headScript()->captureEnd() ?>
  333. ]]></programlisting>
  334. <para>
  335. In unserem Layout Skript wird der Platzhalter dann einfach ausgegeben, wie wir es
  336. bereits bei den anderen gemacht haben:
  337. </para>
  338. <programlisting language="php"><![CDATA[
  339. <?php echo $this->doctype() ?>
  340. <html>
  341. <?php echo $this->headTitle() ?>
  342. <?php echo $this->headLink() ?>
  343. <?php echo $this->headScript() ?>
  344. <!-- ... -->
  345. ]]></programlisting>
  346. <para>
  347. Das erstellt die folgende Ausgabe:
  348. </para>
  349. <programlisting language="html"><![CDATA[
  350. <script type="text/javascript" src="/js/site.js"></script>
  351. <script type="text/javascript" src="/js/user-list.js"></script>
  352. <script type="text/javascript">
  353. site = {
  354. baseUrl: "<?php echo $this->baseUrl() ?>"
  355. };
  356. </script>
  357. ]]></programlisting>
  358. <note>
  359. <title>InlineScript Variante</title>
  360. <para>
  361. Viele Browser blockieren oft die Anzeige von Seiten bis alle Skripte und Stylesheets
  362. geladen wurden auf die in der <code>&lt;head&gt;</code> Sektion referenziert wird.
  363. Wenn man eine Anzahl solcher Direktiven hat, kann das Einfluß darauf haben wie bald
  364. jemand damit beginnen kann sich die Seite anzuschauen:
  365. </para>
  366. <para>
  367. Ein Weg darum zu kommen besteht darin die <code>&lt;script&gt;</code> Tags einfach
  368. nach dem schließenden <code>&lt;body&gt;</code> Tag des Dokuments auszugeben. (Das
  369. ist eine Praxis die speziell vom <ulink
  370. url="http://developer.yahoo.com/yslow/">Y! Slow Projekt</ulink> empfohlen wird)
  371. </para>
  372. <para>
  373. Zend Framework unterstützt das auf zwei unterschiedlichen Wegen:
  374. </para>
  375. <itemizedlist>
  376. <listitem>
  377. <para>
  378. Man kann das <methodname>headScript()</methodname> Tag im Layout Skript
  379. überall wo man will darstellen; nur weil der Titel auf "head" referenziert
  380. heißt das nicht dass er an dieser Position dargestellt werden muss.
  381. </para>
  382. </listitem>
  383. <listitem>
  384. <para>
  385. Alternativ kann der <methodname>inlineScript()</methodname> Helfer verwendet
  386. werden der einfach eine Variante von <methodname>headScript()</methodname>
  387. ist und das selbe Verhalten hat, aber eine eigene Registry verwendet.
  388. </para>
  389. </listitem>
  390. </itemizedlist>
  391. </note>
  392. </sect2>
  393. </sect1>