Zend_Controller-ActionHelpers-AutoComplete.xml 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect3 id="zend.controller.actionhelpers.autocomplete">
  5. <title>AutoComplete</title>
  6. <para>
  7. Viele <acronym>AJAX</acronym> Javascript Bibliotheken bieten Funktionalitäten an für eine
  8. automatische Vervollständigung wobei eine Auswahlliste von potentiell passenden Ergebnissen
  9. angezeigt wird während der Benutzer tippt. Der <emphasis>AutoComplete</emphasis> Helfer
  10. zielt darauf ab einfach akzeptierbare Ergebnisse zu solchen Methoden zurückzugeben.
  11. </para>
  12. <para>
  13. Da nicht alle JS Bibliotheken automatische Vervollständigung auf die gleiche Art
  14. implementieren bietet der <emphasis>AutoComplete</emphasis> Helfer einige grundsätzliche
  15. abstrakte Funktionalitäten zu vielen Bibliotheken und konkrete Implementierungen für
  16. individuelle Bibliotheken. Zurückgegebene Typen sind generell entweder
  17. <acronym>JSON</acronym> Arrays von Strings, <acronym>JSON</acronym> Arrays von Arrays (mit
  18. jedem Mitgliedsarray das ein assoziatives Array von Metadaten ist, das verwendet wird um
  19. die Auswahlliste zu erstellen), oder <acronym>HTML</acronym>.
  20. </para>
  21. <para>
  22. Die grundsätzliche Verwendung ist für jede Implementierung die selbe:
  23. </para>
  24. <programlisting language="php"><![CDATA[
  25. class FooController extends Zend_Controller_Action
  26. {
  27. public function barAction()
  28. {
  29. // etwas Logik durchführen...
  30. // Verschlüsseln und Antwort senden;
  31. $this->_helper->autoCompleteDojo($data);
  32. // oder explizit:
  33. $response = $this->_helper->autoCompleteDojo
  34. ->sendAutoCompletion($data);
  35. // oder einfach die Antwort der automatischen
  36. // Vervollständigung vorbereiten;
  37. $response = $this->_helper->autoCompleteDojo
  38. ->prepareAutoCompletion($data);
  39. }
  40. }
  41. ]]></programlisting>
  42. <para>
  43. Standardmäßig mach die automatische Vervollständigung folgendes:
  44. </para>
  45. <itemizedlist>
  46. <listitem><para>Layouts und ViewRenderer ausschalten.</para></listitem>
  47. <listitem><para>Die richtigen Antwort Header zu setzen.</para></listitem>
  48. <listitem>
  49. <para>
  50. Antwort Body mit verschlüsselten oder formatierten automatisch vervollständigten
  51. Daten setzen.
  52. </para>
  53. </listitem>
  54. <listitem><para>Antwort senden.</para></listitem>
  55. </itemizedlist>
  56. <para>
  57. Mögliche Methoden des Helfers beinhalten:
  58. </para>
  59. <itemizedlist>
  60. <listitem>
  61. <para>
  62. <methodname>disableLayouts()</methodname> kann verwendet werden um Layouts und den
  63. ViewRenderer auszuschalten. Typischerweise wird das innerhalb von
  64. <methodname>prepareAutoCompletion()</methodname> aufgerufen.
  65. </para>
  66. </listitem>
  67. <listitem>
  68. <para>
  69. <methodname>encodeJson($data, $keepLayouts = false)</methodname> verschlüsselt
  70. Daten zu <acronym>JSON</acronym>, und aktiviert oder deaktiviert Layouts optional.
  71. Typischerweise wird das innerhalb von
  72. <methodname>prepareAutoCompletion()</methodname> aufgerufen.
  73. </para>
  74. </listitem>
  75. <listitem>
  76. <para>
  77. <methodname>prepareAutoCompletion($data, $keepLayouts = false)</methodname> wird
  78. verwendet um Daten im Antwortformat vorzubereiten wenn das für die konkrete
  79. Implementation notwendig ist, wobei Layouts optional aktiviert oder deaktiviert
  80. werden können. Der Rückgabewert variiert basierend auf der Implementierung.
  81. </para>
  82. </listitem>
  83. <listitem>
  84. <para>
  85. <methodname>sendAutoCompletion($data, $keepLayouts = false)</methodname> wird
  86. verwendet um Daten im Antwortformat zu senden was für die konkrete Implementierung
  87. notendig ist. Sie ruft <methodname>prepareAutoCompletion()</methodname> und sendet
  88. dann die Antwort.
  89. </para>
  90. </listitem>
  91. <listitem>
  92. <para>
  93. <methodname>direct($data, $sendNow = true, $keepLayouts = false)</methodname> wird
  94. verwendet wenn der Helfer als Methode des Helfer Brokers aufgerufen wird. Das
  95. <varname>$sendNow</varname> Flag wird verwendet um festzustellen ob
  96. <methodname>sendAutoCompletion()</methodname> oder
  97. <methodname>prepareAutoCompletion()</methodname> aufgerufen werden muß.
  98. </para>
  99. </listitem>
  100. </itemizedlist>
  101. <para>
  102. Aktuell unterstützt <emphasis>AutoComplete</emphasis> die folgenden Dojo und Scriptaculous
  103. <acronym>AJAX</acronym> Bibliotheken.
  104. </para>
  105. <sect4 id="zend.controller.actionhelpers.autocomplete.dojo">
  106. <title>AutoCompletion mit Dojo</title>
  107. <para>
  108. Dojo hat per se keinen AutoCompletion Wizard, hat aber zwei Wizards die AutoCompletion
  109. ausführen können: ComboBox und FilteringSelect. In beiden Fällen benötigen Sie einen
  110. Datenspeicher der QueryReadStore implementiert; für mehr Informationen über dieses
  111. Thema siehe die <ulink
  112. url="http://dojotoolkit.org/reference-guide/dojo/data.html">dojo.data</ulink>
  113. Dokumentation.
  114. </para>
  115. <para>
  116. Im Zend Framework kann ein einfaches indiziertes Array an den AutoCompletionDojo Helfer
  117. übergeben werden, und er wird eine <acronym>JSON</acronym> Antwort zurückgeben die
  118. passend für die Verwendung in so einem Speicher ist:
  119. </para>
  120. <programlisting language="php"><![CDATA[
  121. // In der Controller Aktion:
  122. $this->_helper->autoCompleteDojo($data);
  123. ]]></programlisting>
  124. <example id="zend.controller.actionhelpers.autocomplete.dojo.example1">
  125. <title>AutoCompletion mit Dojo und der Verwendung von Zend MVC</title>
  126. <para>
  127. AutoCompletion mit Dojo, über Zend <acronym>MVC</acronym>, benötigt verschiedene
  128. Dinge: Erstellung eines Form Objekts für die Kombobox bei der man AutoCompletion
  129. will, eine Controller Action für das anbieten der AutoCompletion Ergebnisse,
  130. Erstellung eines eigenen QueryReadSote um die AutoCompletion Aktion damit zu
  131. verbinden, und Erstellung des Javascripts das zur Initialisierung der
  132. AutoCompletion auf der Serverseite zu verwenden ist.
  133. </para>
  134. <para>
  135. Schauen wir uns zuerst das benötigte Javascript an. Dojo bietet ein komplettes
  136. Framework für die Erstellung von <acronym>OOP</acronym> Javascript, so wie Zend
  137. Framework für <acronym>PHP</acronym>. Teile davon sind die Möglichkeit
  138. Pseudo-Namespaces zu erstellen indem die Verzeichnis Hirarchie verwendet wird. Wir
  139. erstellen ein 'custom' Verzeichnis auf dem gleichen Level wie das Dojo Verzeichnis
  140. das Teil der Distribution von Dojo ist. In diesem Verzeichnis, erstellen wir eine
  141. Javascript Datei, <filename>TestNameReadStore.js</filename>, mit den folgenden
  142. Inhalten:
  143. </para>
  144. <programlisting language="javascript"><![CDATA[
  145. dojo.provide("custom.TestNameReadStore");
  146. dojo.declare("custom.TestNameReadStore", dojox.data.QueryReadStore, {
  147. fetch:function (request) {
  148. request.serverQuery = { test:request.query.name };
  149. return this.inherited("fetch", arguments);
  150. }
  151. });
  152. ]]></programlisting>
  153. <para>
  154. Diese Klasse ist einfach eine Erweiterung von Dojo's eigenem QueryReadStore,
  155. welche selbst eine Abstrakte Klasse ist. Wir definieren einfach eine Methode mit
  156. der angefragt werden soll, und verknüpfen Sie mit dem 'test' Element.
  157. </para>
  158. <para>
  159. Als nächstes, erstellen wir das Form Element für das wir AutoCompletion wollen:
  160. </para>
  161. <programlisting language="php"><![CDATA[
  162. class TestController extends Zend_Controller_Action
  163. {
  164. protected $_form;
  165. public function getForm()
  166. {
  167. if (null === $this->_form) {
  168. $this->_form = new Zend_Form();
  169. $this->_form->setMethod('get')
  170. ->setAction(
  171. $this->getRequest()->getBaseUrl() . '/test/process'
  172. )
  173. ->addElements(array(
  174. 'test' => array('type' => 'text', 'options' => array(
  175. 'filters' => array('StringTrim'),
  176. 'dojoType' => array('dijit.form.ComboBox'),
  177. 'store' => 'testStore',
  178. 'autoComplete' => 'false',
  179. 'hasDownArrow' => 'true',
  180. 'label' => 'Your input:',
  181. )),
  182. 'go' => array('type' => 'submit',
  183. 'options' => array('label' => 'Go!'))
  184. ));
  185. }
  186. return $this->_form;
  187. }
  188. }
  189. ]]></programlisting>
  190. <para>
  191. Hier erstellen wir einfach eine Form mit den 'test' und 'go' Methoden. Die 'test'
  192. Methode fügt verschiedene spezielle, Dojo-spezifische Attribute hinzu: dojoType,
  193. store, autoComplete, und hasDownArrow. Der dojoType wird verwendet um anzuzeigen
  194. das wir eine ComboBox erstellen, und wir Sie zum Datenspeicher von 'testStore'
  195. verbinden wollen (Schlüssel 'store') -- mehr dazu später. Die Spezifizierung von
  196. 'autoComplete' mit <constant>FALSE</constant> sagt Dojo das der erste passende
  197. Eintrag nicht automatisch ausgewählt wird, aber stattdessen eine Liste von
  198. Entsprechnungen angezeigt wird. Letztendlich, erstellt 'hasDownArrow' einen
  199. Abwärtspfeil ähnlich einer Selectbox sodas Wir die Entsprechnungen zeigen und
  200. verstecken können.
  201. </para>
  202. <para>
  203. Fügen wir eine Methode hinzu um die Form anzuzeigen, sowie einen Endpunkt für die
  204. Bearbeitung der AutoCompletion:
  205. </para>
  206. <programlisting language="php"><![CDATA[
  207. class TestController extends Zend_Controller_Action
  208. {
  209. // ...
  210. /**
  211. * Startseite
  212. */
  213. public function indexAction()
  214. {
  215. $this->view->form = $this->getForm();
  216. }
  217. public function autocompleteAction()
  218. {
  219. if ('ajax' != $this->_getParam('format', false)) {
  220. return $this->_helper->redirector('index');
  221. }
  222. if ($this->getRequest()->isPost()) {
  223. return $this->_helper->redirector('index');
  224. }
  225. $match = trim($this->getRequest()->getQuery('test', ''));
  226. $matches = array();
  227. foreach ($this->getData() as $datum) {
  228. if (0 === strpos($datum, $match)) {
  229. $matches[] = $datum;
  230. }
  231. }
  232. $this->_helper->autoCompleteDojo($matches);
  233. }
  234. }
  235. ]]></programlisting>
  236. <para>
  237. in unserer <methodname>autocompleteAction()</methodname> machen wir eine Anzahl von
  238. Dingen. Zuerst schauen wir darauf eine Post Anfrage durchzuführen, und das dort ein
  239. 'format' Parameter auf den Wert 'ajax' gesetzt ist; das hilft einfach störende
  240. Anfragen zur Aktion zu reduzieren. Als nächstes prüfen wir auf den 'test'
  241. Parameter, und vergleichen Ihn mit unseren Daten. (wir haben absichtlich die
  242. Implementation von <methodname>getData()</methodname> hier ausgelassen -- es können
  243. einfach jede Art von Datenquelle sein.) Letztendlich senden wir unsere
  244. Entsprechungen zum AutoCompletion Helfer.
  245. </para>
  246. <para>
  247. Jetzt da wir alle Teile des Backends haben, sehen wir uns an was wir benötigen um
  248. es in unserem View Skript für die Startseite auszugeben. Zuerst müssen wir unseren
  249. Datenspeicher einstellen, dann unsere Form darstellen, und letztendlich
  250. sicherstellen das die richtigen Dojo Bibliotheken -- inklusive unserer eigenen
  251. Datenspeicher -- geladen werden. Schauen wir uns das View Skript an, das die
  252. Schritte kommentiert:
  253. </para>
  254. <programlisting language="php"><![CDATA[
  255. <?php // Den Datenspeicher einstellen: ?>
  256. <div dojoType="custom.TestNameReadStore" jsId="testStore"
  257. url="<?php echo $this->baseUrl() ?>/unit-test/autocomplete/format/ajax"
  258. requestMethod="get"></div>
  259. <?php // Die Form darstellen: ?>
  260. <?php echo $this->form ?>
  261. <?php // Das Dojo-betreffende CSS einstellen das im
  262. // HTML Head geladen werden soll: ?>
  263. <?php $this->headStyle()->captureStart() ?>
  264. @import "<?php echo $this->baseUrl()
  265. ?>/javascript/dijit/themes/tundra/tundra.css";
  266. @import "<?php echo $this->baseUrl() ?>/javascript/dojo/resources/dojo.css";
  267. <?php $this->headStyle()->captureEnd() ?>
  268. <?php // Javascript einstellen das im HTML Head geladen werden soll,
  269. // inklusive aller benötigten Dojo Bibliotheken: ?>
  270. <?php $this->headScript()
  271. ->setAllowArbitraryAttributes(true)
  272. ->appendFile($this->baseUrl() . '/javascript/dojo/dojo.js',
  273. 'text/javascript',
  274. array('djConfig' => 'parseOnLoad: true'))
  275. ->captureStart() ?>
  276. djConfig.usePlainJson=true;
  277. dojo.registerModulePath("custom","../custom");
  278. dojo.require("dojo.parser");
  279. dojo.require("dojox.data.QueryReadStore");
  280. dojo.require("dijit.form.ComboBox");
  281. dojo.require("custom.TestNameReadStore");
  282. <?php $this->headScript()->captureEnd() ?>
  283. ]]></programlisting>
  284. <para>
  285. Beachte die Aufrufe zu den View Helfern wie headStyle und headScript; das sind
  286. Platzhalter, welche dann in der <acronym>HTML</acronym> Head Sektion des Layout
  287. View Skripts dargestellt werden können.
  288. </para>
  289. <para>
  290. Wir haben jetzt alle Teil um mit Dojo AutoCompletion zu arbeiten.
  291. </para>
  292. </example>
  293. </sect4>
  294. <sect4 id="zend.controller.actionhelpers.autocomplete.scriptaculous">
  295. <title>AutoCompletion mit Scriptaculous</title>
  296. <para>
  297. <ulink
  298. url="http://wiki.script.aculo.us/scriptaculous/show/Ajax.Autocompleter">Scriptaculous</ulink>
  299. erwartet eine <acronym>HTML</acronym> Antwort in einem speziellen Format.
  300. </para>
  301. <para>
  302. Der Helfer der mit dieser Bibliothek zu verwenden ist 'AutoCompleteScriptaculous'.
  303. Es muß einfach ein Array von Daten angegeben werden, und der Helfer wird eine
  304. <acronym>HTML</acronym> Antwort erstellen die mit Ajax.Autocompleter kompatibel ist.
  305. </para>
  306. </sect4>
  307. </sect3>