Zend_Dojo-View-Dojo.xml 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15156 -->
  3. <!-- Reviewed: no -->
  4. <sect2 id="zend.dojo.view.dojo">
  5. <title>dojo() View Helfer</title>
  6. <para>
  7. Der <code>dojo()</code> View Helfer ist dazu gedacht das konfigurieren der Dojo Umgebung zu vereinfachen,
  8. was die folgenden Notwendigkeiten beinhaltet:
  9. </para>
  10. <itemizedlist>
  11. <listitem><para>Spezifizieren eines CDN oder lokalen Pfades zu einer Dojo Installation.</para></listitem>
  12. <listitem><para>Spezifizieren von Pfaden zu eigenen Dojo Modulen.</para></listitem>
  13. <listitem><para>Spezifizieren von dojo.require Statements.</para></listitem>
  14. <listitem><para>Spezifizieren von Dijit Stylesheet Themen zur Verwendung.</para></listitem>
  15. <listitem><para>Spezifizieren von dojo.addOnLoad() Events.</para></listitem>
  16. </itemizedlist>
  17. <para>
  18. Die <code>dojo()</code> View Helfer Implementation ist ein Beispiel einer Platzhalter Implementation.
  19. Das Datenset in Ihm ist persistent zwischen den View Objekten, und kann direkt im eigenen
  20. Layout Skript ausgegeben werden.
  21. </para>
  22. <example id="zend.dojo.view.dojo.usage">
  23. <title>Beispiel für die Verwendung des dojo() View Helfers</title>
  24. <para>
  25. Für dieses Beispiel nehmen wir an das der Entwickler Dojo von einem lokalen Pfad aus verwenden
  26. wird, verschiedene Dijits benötigt, und das Tundra Dijit Thema anpasst.
  27. </para>
  28. <para>
  29. Auf vielen Seiten, kann der Entwickler Dojo nicht einmal verwenden. Deshalb werden wir uns zuerst
  30. auf ein View Skript fokusieren indem Dojo benötigt wird, und dann auf das Layout Skript, indem wir
  31. einiges der Dojo Umgebung einstellen und anschließend darstellen werden.
  32. </para>
  33. <para>
  34. Zuerst müssen wir unserem View Objekt mitteilen das es die Dojo View Helferpfade verwenden soll.
  35. Das kann in der eigenen Bootstrap Datei getan werden oder in einem Plugin das früh abläuft;
  36. einfach das View Objekt nehmen und das folgende ausführen:
  37. </para>
  38. <programlisting role="php"><![CDATA[
  39. $view->addHelperPath('Zend/Dojo/View/Helper/', 'Zend_Dojo_View_Helper');
  40. ]]></programlisting>
  41. <para>
  42. Als nächstes das View Skript. In diesem Fall werden die spezifizieren das ein FilterSelect
  43. verwendet werden soll -- welcher einen eigenen Speicher basierend auf QueryReadStore verwenden
  44. wird, und den wir 'PairedStore' nennen und in unserem 'custom' Modul speichern.
  45. </para>
  46. <programlisting role="php"><![CDATA[
  47. <?php // Datenspeicher für FilteringSelect einstellen ?>
  48. <div dojoType="custom.PairedStore" jsId="stateStore"
  49. url="/data/autocomplete/type/state/format/ajax"
  50. requestMethod="get"></div>
  51. <?php // Eingabeelement: ?>
  52. State: <input id="state" dojoType="dijit.form.FilteringSelect"
  53. store="stateStore" pageSize="5" />
  54. <?php // Notwendige Dojo Elemente einstellen:
  55. $this->dojo()->enable()
  56. ->setDjConfigOption('parseOnLoad', true)
  57. ->registerModulePath('custom', '../custom/')
  58. ->requireModule('dijit.form.FilteringSelect')
  59. ->requireModule('custom.PairedStore'); ?>
  60. ]]></programlisting>
  61. <para>
  62. In unserem Layout Skript, prüfen wir anschließend ob Dojo aktiviert ist, und wenn das der Fall ist,
  63. erledigen wir einige generelle Konfigurationen und fügen Sie hinzu:
  64. </para>
  65. <programlisting role="php"><![CDATA[
  66. <?php echo $this->doctype() ?>
  67. <html>
  68. <head>
  69. <?php echo $this->headTitle() ?>
  70. <?php echo $this->headMeta() ?>
  71. <?php echo $this->headLink() ?>
  72. <?php echo $this->headStyle() ?>
  73. <?php if ($this->dojo()->isEnabled()){
  74. $this->dojo()->setLocalPath('/js/dojo/dojo.js')
  75. ->addStyleSheetModule('dijit.themes.tundra');
  76. echo $this->dojo();
  77. }
  78. ?>
  79. <?php echo $this->headScript() ?>
  80. </head>
  81. <body class="tundra">
  82. <?php echo $this->layout()->content ?>
  83. <?php echo $this->inlineScript() ?>
  84. </body>
  85. </html>
  86. ]]></programlisting>
  87. <para>
  88. An diesem Punkt muß man nur sicherstellen das die Dateien am richtigen Ort vorhanden sind und
  89. das man die Aktion des Endpunktes für das FilteringSelect erstellt hat!
  90. </para>
  91. </example>
  92. <sect3 id="zend.dojo.view.dojo.declarative">
  93. <title>Programtechnische und Deklarative Verwendung von Dojo</title>
  94. <para>
  95. Dojo erlaubt sowohl die <emphasis>deklarative</emphasis> als auch die
  96. <emphasis>programmtechnische</emphasis> Verwendung von vielen Ihrer Features.
  97. <emphasis>Deklarative</emphasis> Verwendung verwendet Standard HTML Elemente mit nicht-standard
  98. Attributen die geparst werden wenn die Seite geladen wird. Wärend das eine mächtige und einfach
  99. verwendbare Syntax ist, kann Sie für viele Entwickler Probleme bei der Überprüfung einer Seite
  100. verursachen.
  101. </para>
  102. <para>
  103. <emphasis>Programmtechnische</emphasis> Verwendung erlaubt dem Entwickler existierende Elemente
  104. zu dekorieren indem Sie anhand von ID oder CSS Selektoren geholt werden und dem entsprechenden
  105. Objektkonstruktoren in Dojo übergeben werden. Weil keine nicht-standard HTML Attribute verwendet
  106. werden, bleiben Seiten hiermit gültig.
  107. </para>
  108. <para>
  109. In der Praxis, erlauben beide Fälle eine zierliche Degeneration wenn Javascript ausgeschaltet ist,
  110. oder die verschiedenen Dojo Skriptresourcen nicht erreichbar sind. Um Standards und
  111. Dokumentüberprüfungen zu gestatten verwendet Zend Framework standardmäßig die programmtechnische
  112. Verwendung; die verschiedenen Viewhelfer erzeugen Javascript und übergeben dieses an den
  113. <code>dojo()</code> Viewhelfer für die Einbeziehung wenn er dargestellt wird.
  114. </para>
  115. <para>
  116. Entwickler die diese Technik verwenden wollen eventuell auch die Option kennenlernen mit der Sie
  117. Ihre eigene programmtechnische Deklaration auf der Seite schreiben können. Ein Vorteil wäre die
  118. Möglichkeit Handler für Dijit Events zu spezifizieren.
  119. </para>
  120. <para>
  121. Um das zu erlauben, wie auch die Möglichkeit die deklarative Syntax zu verwenden, sind es eine
  122. Anzahl von statischen Methoden vorhanden die dieses Verhalten global setzen.
  123. </para>
  124. <example id="zend.dojo.view.dojo.declarative.usage">
  125. <title>Spezifizieren der deklarativen und programmtechnischen Verwendung von Dojo</title>
  126. <para>
  127. Um die deklarative Verwendung zu spezifizieren muß einfach die statische
  128. <code>setUseDeclarative()</code> Methode aufgerufen werden:
  129. </para>
  130. <programlisting role="php"><![CDATA[
  131. Zend_Dojo_View_Helper_Dojo::setUseDeclarative();
  132. ]]></programlisting>
  133. <para>
  134. Wenn man stattdessen die programmtechnische Verwendung verwenden will, muß die statische
  135. <code>setUseProgrammatic()</code> Methode aufgerufen werden:
  136. </para>
  137. <programlisting role="php"><![CDATA[
  138. Zend_Dojo_View_Helper_Dojo::setUseProgrammatic();
  139. ]]></programlisting>
  140. <para>
  141. Letztendlich, wenn man programmtechnische Regeln selbst erstellen will, sollte man die
  142. programmtechnische Verwendung spezifizieren, aber den Wert '-1' übergeben; in diesem Fall
  143. wird kein Javascript, für die Dekoration von verwendeten Dijits, erstellt.
  144. </para>
  145. <programlisting role="php"><![CDATA[
  146. Zend_Dojo_View_Helper_Dojo::setUseProgrammatic(-1);
  147. ]]></programlisting>
  148. </example>
  149. </sect3>
  150. <sect3 id="zend.dojo.view.dojo.themes">
  151. <title>Themen</title>
  152. <para>
  153. Dojo erlaubt die Erstellung von Themen für seine Dijits (Widgets). Man kann eines auswählen indem
  154. ein Modulpfad übergeben wird:
  155. </para>
  156. <programlisting role="php"><![CDATA[
  157. $view->dojo()->addStylesheetModule('dijit.themes.tundra');
  158. ]]></programlisting>
  159. <para>
  160. Der Modulpfad wird durch die Verwendung des Zeichens '.' als Trennzeichen vom Verzeichnis erkannt
  161. und der Verwendung des letzten Wertes in der Liste als den Namen der CSS Datei die im
  162. Themenverzeichnis verwendet wird; im obigen Beispiel sucht Dojo das Thema in
  163. 'dijit/themes/tundra/tundra.css'.
  164. </para>
  165. <para>
  166. Wenn ein Thema verwendet wird ist es wichtig daran zu denken die Themenklasse, zumindest an den
  167. Container der jedes Dijit das verwendet wird umgibt, zu übergeben; im üblichsten Fällen wird es
  168. an den Body übergeben:
  169. </para>
  170. <programlisting role="html"><![CDATA[
  171. <body class="tundra">
  172. ]]>
  173. </programlisting>
  174. </sect3>
  175. <sect3 id="zend.dojo.view.dojo.layers">
  176. <title>Layer verwenden (eigene Builds)</title>
  177. <para>
  178. Wenn ein dojo.require Statement verwendet wird, wird Dojo standardmäßig eine Anfrage an den
  179. Server zurücksenden um die richtige Javascript Datei zu holen. Wenn man viele Dijits verwendet,
  180. resultiert das in vielen Anfragen an den Server -- was nicht optimal ist.
  181. </para>
  182. <para>
  183. Dojo's Antwort darauf ist es die Möglichkeit anzubieten <emphasis>eigene Builds</emphasis>
  184. zu erstellen. Builds machen verschiedene Dinge:
  185. </para>
  186. <itemizedlist>
  187. <listitem><para>
  188. Benötigte Dateien in <emphasis>Layern</emphasis> gruppieren; ein Layer sammelt alle
  189. benötigten Dateien in eine einzelne JS Datei. (Daher der Name dieses Kapitels)
  190. </para></listitem>
  191. <listitem><para>
  192. "Interne" nicht-javascript Dateien die von Dijits verwendet werden (typischerweise
  193. Templatedateien). Diese werden auch in der gleichen JS Datei gruppiert wie der Layer.
  194. </para></listitem>
  195. <listitem><para>
  196. Die Datei wird an ShrinkSafe übergeben, welches Leerzeichen und Kommentare entfernt, sowie
  197. Variablennamen verkleinert.
  198. </para></listitem>
  199. </itemizedlist>
  200. <para>
  201. Einige Dateien können nicht in einen Layer gelegt werden, aber der Buildprozess wird ein spezielles
  202. Releaseverzeichnis mit der Layerdatei und allen anderen Dateien erstellen. Das erlaubt es eine
  203. verkleinerte eigene Distribution für die eigene Site oder Anwendungen zu erhalten.
  204. </para>
  205. <para>
  206. Um einen Layer zu verwenden, hat der <code>dojo()</code> Viewhelfer eine <code>addLayer()</code>
  207. Methode für das hinzufügen von Pfaden zu benötigten Layern:
  208. </para>
  209. <programlisting role="html"><![CDATA[
  210. $view->dojo()->addLayer('/js/foo/foo.js');
  211. ]]></programlisting>
  212. <para>
  213. Für weitere Informationen über die Erstellung von eigenen Build, schauen Sie bitte
  214. <ulink url="http://dojotoolkit.org/book/dojo-book-0-9/part-4-meta-dojo/package-system-and-custom-builds">
  215. in die Dojo Builddokumentation</ulink>.
  216. </para>
  217. </sect3>
  218. <sect3 id="zend.dojo.view.dojo.methods">
  219. <title>Vorhandene Methoden</title>
  220. <para>
  221. Der <code>dojo()</code> Viewhelfer gibt immer eine Instanz des Dojo Platzhaltercontainers zurück.
  222. Dieses Containerobjekt bietet die folgenden Methoden an:
  223. </para>
  224. <itemizedlist>
  225. <listitem><para><code>setView(Zend_View_Interface $view)</code>: Setzt eine Viewinstanz
  226. im Container</para></listitem>
  227. <listitem><para><code>enable()</code>: Die Dojo Integration explizit einschalten.</para></listitem>
  228. <listitem><para><code>disable()</code>: Die Dojo Integration ausschalten.</para></listitem>
  229. <listitem><para><code>isEnabled()</code>: Ermitteln ob die Dojo Integration eingeschaltet
  230. ist oder nicht.</para></listitem>
  231. <listitem><para><code>requireModule($module)</code>: Ein <code>dojo.require</code>
  232. Statement konfigurieren.</para></listitem>
  233. <listitem><para><code>getModules()</code>: Erkennen welche Module benötigt werden.</para></listitem>
  234. <listitem><para><code>registerModulePath($module, $path)</code>:
  235. Einen Dojo Modulpfad registrieren.</para></listitem>
  236. <listitem><para><code>getModulePaths()</code>: Eine Liste von registrierten Modulpfaden
  237. erhalten.</para></listitem>
  238. <listitem><para><code>addLayer($path)</code>: Einen Layerpfad (eigenen Build) für die
  239. Verwendung hinzufügen.</para></listitem>
  240. <listitem><para><code>getLayers()</code>: Eine Liste von allen registrierten Layerpfaden (eigene
  241. Builds) erhalten.</para></listitem>
  242. <listitem><para><code>removeLayer($path)</code>: Den Layer der <code>$path</code> entspricht
  243. von der Liste der registrierten Layer (eigene Builds) entfernen.</para></listitem>
  244. <listitem><para><code>setCdnBase($url)</code>: Den Basis URL für ein CDN setzen; typischerweise
  245. ist das <classname>Zend_Dojo::CDN_BASE_AOL</classname> oder
  246. <classname>Zend_Dojo::CDN_BASE_GOOGLE</classname>, aber es wird der URL String vor der Versionsnummer
  247. benötigt.</para></listitem>
  248. <listitem><para><code>getCdnBase()</code>: Den Basis CDN URL empfangen.</para></listitem>
  249. <listitem><para><code>setCdnVersion($version = null)</code>: Setzen selche Version von Dojo vom
  250. CDN verwendet wird.</para></listitem>
  251. <listitem><para><code>getCdnVersion()</code>: Die Dojo Version vom CDN erhalten die verwendet
  252. wird.</para></listitem>
  253. <listitem><para><code>setCdnDojoPath($path)</code>: Setzt den relativen Pfad zur dojo.js oder
  254. dojo.xd.js Datei am CDN; typischerweise ist das entweder
  255. <classname>Zend_Dojo::CDN_DOJO_PATH_AOL</classname> oder <classname>Zend_Dojo::CDN_DOJO_PATH_GOOGLE</classname>,
  256. aber es wird der Pfadstring nach der Versionsnummer benötigt.</para></listitem>
  257. <listitem><para><code>getCdnDojoPath()</code>: Das letzte Pfadsegment der CDN URL erhalten das auf
  258. die dojo.js Datei zeigt.</para></listitem>
  259. <listitem><para><code>useCdn()</code>: Dem Container mitteilen das CDN verwendet werden soll;
  260. aktiviert die Integration implizit.</para></listitem>
  261. <listitem><para><code>setLocalPath($path)</code>: Dem Container den Pfad zu einer lokalen Dojo
  262. Installation mitteilen (sollte ein Pfad relativ zum Server sein, und die dojo.js Datei
  263. selbst enthalten); aktiviert die Integration implizit.</para></listitem>
  264. <listitem><para><code>getLocalPath()</code>: Erkennen welches lokale Pfad zu Dojo verwendet wird.</para></listitem>
  265. <listitem><para><code>useLocalPath()</code>: Verwendet die Integration einen lokalen Dojopfad?</para></listitem>
  266. <listitem><para><code>setDjConfig(array $config)</code>: Setzt Dojo/Dijit Konfigurationswerte
  267. (erwartet ein assoziatives Array).</para></listitem>
  268. <listitem><para><code>setDjConfigOption($option, $value)</code>: Setzt einen einzelnen
  269. Dojo/Dijit Konfigurationswert.</para></listitem>
  270. <listitem><para><code>getDjConfig()</code>: Retourniert alle Dojo/Dijit Konfigurationswerte.</para></listitem>
  271. <listitem><para><code>getDjConfigOption($option, $default = null)</code>: Retourniert einen
  272. einzelnen Dojo/Dijit Konfigurationswert.</para></listitem>
  273. <listitem><para><code>addStylesheetModule($module)</code>: Fügt ein Stylesheet hinzu basierend auf
  274. einem Modulthema.</para></listitem>
  275. <listitem><para><code>getStylesheetModules()</code>: Retourniert die als Modulthema registrierten
  276. Modulthemen.</para></listitem>
  277. <listitem><para><code>addStylesheet($path)</code>: Fügt einen lokalen Stylesheet zur Verwendung
  278. mit Dojo hinzu.</para></listitem>
  279. <listitem><para><code>getStylesheets()</code>: Retourniert die lokalen Dojo Stylesheets.</para></listitem>
  280. <listitem><para><code>addOnLoad($spec, $function = null)</code>: Fügt ein Lambda für dojo.onLoad
  281. hinzu das dieses aufruft. Wenn ein Argument übergeben wird, wird dieses entweder als
  282. Funktionsname oder als Javascriptabschluss angenommen. Wenn zwei Argumente übergeben werden,
  283. wird das erste als Name der Variablen der Objektinstanz angenommen und der zweite entweder
  284. als Methodenname in diesem Objekt oder ein Abschluß um dieses Objekt zu verwenden.</para></listitem>
  285. <listitem><para><code>prependOnLoad($spec, $function = null)</code>:
  286. genau wie <code>addOnLoad()</code>, außer das vor den Anfang des onLoad Stacks
  287. angefügt wird.</para></listitem>
  288. <listitem><para><code>getOnLoadActions()</code>: Gibt alle im Container registrierten
  289. dojo.onLoad Aktionen zurück. Das ist ein Array von Arrays.</para></listitem>
  290. <listitem><para><code>onLoadCaptureStart($obj = null)</code>: Empfange Daten die als Lambda für
  291. dojo.onLoad() verwendet werden sollen. Wenn $obj angegeben wird, wird der bekommene JS Code
  292. als Abschluß angenommen der mit diesem Javascript Objekt verwendet werden soll.</para></listitem>
  293. <listitem><para><code>onLoadCaptureEnd($obj = null)</code>: Beendet das Empfangen von Daten für
  294. die Verwendung mit dojo.onLoad().</para></listitem>
  295. <listitem><para><code>javascriptCaptureStart()</code>: Empfange Javascript das im Dojo JS inkludiert
  296. werden soll (onLoad, require, und andere Anweisungen).</para></listitem>
  297. <listitem><para><code>javascriptCaptureEnd()</code>: Beende das Empfangen von Javascript.</para></listitem>
  298. <listitem><para><code>__toString()</code>: Castet den Container zu einem String; stellt alle HTML
  299. Stile und Skriptelemente dar.</para></listitem>
  300. </itemizedlist>
  301. </sect3>
  302. </sect2>
  303. <!--
  304. vim:se ts=4 sw=4 et:
  305. -->