Zend_Form-QuickStart.xml 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15854 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.form.quickstart">
  5. <title>Schnellstart mit Zend_Form</title>
  6. <para>
  7. Diese Anleitung soll die Grundsätze der Erstellung, Validierung und
  8. Darstellung von Formularen mit <classname>Zend_Form</classname> zeigen.
  9. </para>
  10. <sect2 id="zend.form.quickstart.create">
  11. <title>Ein Form Objekt erstellen</title>
  12. <para>
  13. Die Erstellung eines Formular Objektes ist sehr einfach: nur
  14. <classname>Zend_Form</classname> instanzieren:
  15. </para>
  16. <programlisting language="php"><![CDATA[
  17. $form = new Zend_Form;
  18. ]]></programlisting>
  19. <para>
  20. Für fortgeschrittene Anwendungsfälle, kann man eine <classname>Zend_Form</classname>
  21. Unterklasse erstellen, aber für einfache Formulare, kann ein Formular programmtechnisch
  22. mit einem <classname>Zend_Form</classname> erstellt werden.
  23. </para>
  24. <para>
  25. Wenn man bei einem Formular Aktion und Methode spezifizieren will (immer eine gute
  26. Idee), kann das mit den <code>setAction()</code> und <code>setMethod()</code> Methoden
  27. gemacht werden:
  28. </para>
  29. <programlisting language="php"><![CDATA[
  30. $form->setAction('/resource/process')
  31. ->setMethod('post');
  32. ]]></programlisting>
  33. <para>
  34. Der obige Code setzt die Formular Aktion zu der partiellen URL "/resource/process" und
  35. die Formular Methode zu HTTP POST. Das wird während der endgültigen Darstellung
  36. berücksichtigt.
  37. </para>
  38. <para>
  39. Man kann zusätzliche HTML Attribute für das <code>&lt;form&gt;</code> Tag setzen, indem
  40. die <code>setAttrib()</code> oder <code>setAttribs()</code> Methoden verwendet werden.
  41. Zum Beispiel wenn man die ID setzen will, setzt man das "id" Attribut:
  42. </para>
  43. <programlisting language="php"><![CDATA[
  44. $form->setAttrib('id', 'login');
  45. ]]></programlisting>
  46. </sect2>
  47. <sect2 id="zend.form.quickstart.elements">
  48. <title>Elemente einer Form hinzufügen</title>
  49. <para>
  50. Ein Formular ist nichts ohne seine Elemente. <classname>Zend_Form</classname> kommt mit
  51. einigen Standardelementen die XHTML über <classname>Zend_View</classname> Helfer
  52. darstellen. Das sind die folgenden:
  53. </para>
  54. <itemizedlist>
  55. <listitem><para>
  56. button
  57. </para></listitem>
  58. <listitem><para>
  59. checkbox (oder viele Checkboxen auf einmal mit multiCheckbox)
  60. </para></listitem>
  61. <listitem><para>
  62. hidden
  63. </para></listitem>
  64. <listitem><para>
  65. image
  66. </para></listitem>
  67. <listitem><para>
  68. password
  69. </para></listitem>
  70. <listitem><para>
  71. radio
  72. </para></listitem>
  73. <listitem><para>
  74. reset
  75. </para></listitem>
  76. <listitem><para>
  77. select (beide, normale und Mehrfachauswahl Typen)
  78. </para></listitem>
  79. <listitem><para>
  80. submit
  81. </para></listitem>
  82. <listitem><para>
  83. text
  84. </para></listitem>
  85. <listitem><para>
  86. textarea
  87. </para></listitem>
  88. </itemizedlist>
  89. <para>
  90. Es gibt zwei Optionen für das Hinzufügen von Elementen zu einem Formular: Man kann ein
  91. konkretes Element instanzieren und dieses dem Objekt übergeben, oder man kann den Typ
  92. des Elements übergeben und <classname>Zend_Form</classname> ein Objekt des richtigen
  93. Typs für einen instanzieren lassen.
  94. </para>
  95. <para>
  96. Einige Beispiele:
  97. </para>
  98. <programlisting language="php"><![CDATA[
  99. // Ein Element instanzieren und an das Form Objekt übergeben:
  100. $form->addElement(new Zend_Form_Element_Text('username'));
  101. // Den Fyp des Form Elements dem Form Objekt übergeben:
  102. $form->addElement('text', 'username');
  103. ]]></programlisting>
  104. <para>
  105. Standardmäßig haben diese Elemente keine Prüfer oder Filter. Das bedeutet, dass man
  106. eigene Elemente mit minimalen Prüfern und potentiellen Filtern konfigurieren muss. Man
  107. kann das entweder (a) vor der Übergabe des Elements an das Formular machen, (b) über
  108. Konfigurationsoptionen die bei der Erstellung des Elements über
  109. <classname>Zend_Form</classname> angegeben werden, oder (c), durch beziehen des Elements
  110. vom Formular Objekt und dessen Konfiguration im nachhinein.
  111. </para>
  112. <para>
  113. Betrachten wir zuerst die Erstellung eines Prüfers für eine konkrete Instanz eines
  114. Elements. Es können entweder <classname>Zend_Validate_*</classname> Instanzen übergeben
  115. werden, oder der Name des Prüfers, der verwendet werden soll:
  116. </para>
  117. <programlisting language="php"><![CDATA[
  118. $username = new Zend_Form_Element_Text('username');
  119. // Ein Zend_Validate_* Objekt übergeben:
  120. $username->addValidator(new Zend_Validate_Alnum());
  121. // Den Namen des Prüfers übergeben:
  122. $username->addValidator('alnum');
  123. ]]></programlisting>
  124. <para>
  125. Wenn die zweite Option verwendet wird, kann, wenn der Prüfer Argumente im Konstruktor
  126. akzeptiert, diesem ein Array als dritter Parameter übergeben werden:
  127. </para>
  128. <programlisting language="php"><![CDATA[
  129. // Ein Pattern übergeben
  130. $username->addValidator('regex', false, array('/^[a-z]/i'));
  131. ]]></programlisting>
  132. <para>
  133. (Der zweite Parameter wird verwendet um anzuzeigen, ob spätere Prüfer bei einem Fehler
  134. dieses Prüfers ausgeführt werden sollen oder nicht; standardmäßig ist er
  135. <constant>FALSE</constant>.)
  136. </para>
  137. <para>
  138. Es kann auch gewünscht sein, ein Element als benötigt zu spezifizieren. Das kann durch
  139. Verwendung eines Accessors getan werden, oder durch die Übergabe einer Option bei der
  140. Erstellung des Elemetns. Im ersteren Fall:
  141. </para>
  142. <programlisting language="php"><![CDATA[
  143. // Dieses Element als benötigt definieren:
  144. $username->setRequired(true);
  145. ]]></programlisting>
  146. <para>
  147. Wenn ein Element benötigt wird, wird ein 'NotEmpty' Prüfer ganz oben in der Prüfkette
  148. definiert, um sicherzustellen, dass dieses Element einen Wert hat wenn er benötigt wird.
  149. </para>
  150. <para>
  151. Filter werden grundsätzlich auf dem gleichen Weg, wie die Prüfer, definiert. Zu
  152. Anschauungszwecken, wird ein Filter hinzugefügt, der den endgültigen Wert
  153. klein schreibt:
  154. </para>
  155. <programlisting language="php"><![CDATA[
  156. $username->addFilter('StringtoLower');
  157. ]]></programlisting>
  158. <para>
  159. Das endgültige Setup, des Elements, könnte wie folgt aussehen:
  160. </para>
  161. <programlisting language="php"><![CDATA[
  162. $username->addValidator('alnum')
  163. ->addValidator('regex', false, array('/^[a-z]/'))
  164. ->setRequired(true)
  165. ->addFilter('StringToLower');
  166. // oder kompakter:
  167. $username->addValidators(array('alnum',
  168. array('regex', false, '/^[a-z]/i')
  169. ))
  170. ->setRequired(true)
  171. ->addFilters(array('StringToLower'));
  172. ]]></programlisting>
  173. <para>
  174. So einfach das ist, ist das für jedes einzelne Elemet in einer Form sehr aufwendig.
  175. Versuchen wir es also mit Option (b) von oben. Wenn wir ein neues Element erstellen
  176. wird <classname>Zend_Form::addElement()</classname> als Factory verwendet, und wir
  177. können optional Konfigurationsoptionen übergeben. Diese können Prüfer und Filter
  178. enthalten die angepasst werden können. Um alles von oben implizit durchzuführen,
  179. versuchen wir folgendes:
  180. </para>
  181. <programlisting language="php"><![CDATA[
  182. $form->addElement('text', 'username', array(
  183. 'validators' => array(
  184. 'alnum',
  185. array('regex', false, '/^[a-z]/i')
  186. ),
  187. 'required' => true,
  188. 'filters' => array('StringToLower'),
  189. ));
  190. ]]></programlisting>
  191. <note><para>
  192. Wenn man sieht, dass man Elemente die die gleichen Optionen in vielen Plätzen verwenden,
  193. konfiguriert, kann es gewünscht sein, eine eigene
  194. <classname>Zend_Form_Element</classname> Unterklasse zu erstellen und diese stattdessen
  195. anzupassen; das spart viel Tipparbeit im weiteren Verlauf.
  196. </para></note>
  197. </sect2>
  198. <sect2 id="zend.form.quickstart.render">
  199. <title>Ein Formular darstellen</title>
  200. <para>
  201. Die Darstellung eines Formulars ist einfach. Die meisten Elemente verwenden einen
  202. <classname>Zend_View</classname> Helfer, um sich selbst darzustellen und benötigen
  203. deshalb ein View Objekt, um dargestellt zu werden. Dafür gibt es zwei unterschiedliche
  204. Varianten: Die <code>render()</code> Methode des Formulare verwenden, oder ein einfaches
  205. <code>echo</code>.
  206. </para>
  207. <programlisting language="php"><![CDATA[
  208. // Explizit render() aufrufen und ein optionales View Objekt übergeben:
  209. echo $form->render($view);
  210. // Angenommen ein View Objekt wurde vorher über setView() gesetzt:
  211. echo $form;
  212. ]]></programlisting>
  213. <para>
  214. Standardmäßig versuchen <classname>Zend_Form</classname> und
  215. <classname>Zend_Form_Element</classname> ein im <code>ViewRenderer</code>
  216. initialisiertes View Objekt zu verwenden, was bedeutet, dass die View nicht manuell
  217. gesetzt werden muss, wenn das MVC des Zend Frameworks verwendet wird. Die Darstellung
  218. eines Formulars in einem View Skript ist sehr einfach:
  219. </para>
  220. <programlisting language="php"><![CDATA[
  221. <?php $this->form ?>
  222. ]]></programlisting>
  223. <para>
  224. Unter der Hand verwendet <classname>Zend_Form</classname> "Dekoratoren" um die
  225. Darstellung durchzuführen. Diese Dekoratoren können Inhalte ersetzen, anfügen oder
  226. voranstellen, und haben eine volle Introspektive des Elements das Ihnen übergeben wurde.
  227. Als Ergebnis können mehrere Dekoratoren kombiniert werden, um eigene Effekte zu
  228. ermöglichen. Standardmüßig kombiniert <classname>Zend_Form_Element</classname> View
  229. Dekoratoren um seine Ausgaben zu erstellen; das Setup sieht ähnlich diesem aus:
  230. </para>
  231. <programlisting language="php"><![CDATA[
  232. $element->addDecorators(array(
  233. 'ViewHelper',
  234. 'Errors',
  235. array('HtmlTag', array('tag' => 'dd')),
  236. array('Label', array('tag' => 'dt')),
  237. ));
  238. ]]></programlisting>
  239. <!-- TODO: Wozu gehört dieser Paragraph? Ich sehe nirgends "HELPERNAME". -->
  240. <para>
  241. (Wobei &lt;HELPERNAME&gt; der Name des View Helfers ist der verwendet wird, und
  242. variiert basierend auf dem Element.)
  243. </para>
  244. <para>
  245. Das obige Beispiel erstellt eine Ausgabe, ähnlich der folgenden:
  246. </para>
  247. <programlisting language="html"><![CDATA[
  248. <dt><label for="username" class="required">Username</dt>
  249. <dd>
  250. <input type="text" name="username" value="123-abc" />
  251. <ul class="errors">
  252. <li>'123-abc' has not only alphabetic and digit characters</li>
  253. <li>'123-abc' does not match against pattern '/^[a-z]/i'</li>
  254. </ul>
  255. </dd>
  256. ]]></programlisting>
  257. <para>
  258. (Wenngleich nicht mit der gleichen Formatierung.)
  259. </para>
  260. <para>
  261. Die Dekoratoren die von einem Element verwendet werden, können geändert werden, um eine
  262. andere Ausgabe zu erzeugen; seihe dazu das
  263. <link linkend="zend.form.decorators">Kapitel über Dekoratoren</link> für mehr
  264. Informationen.
  265. </para>
  266. <para>
  267. Das Formular selbst, geht alle Elemente durch, und fügt diese in eine HTML
  268. <code>&lt;form&gt;</code> ein. Die Aktion und Methode, die bei der Erstellung des
  269. Formulars angegeben wurden, werden dem <code>&lt;form&gt;</code> Tag angegeben, wie wenn
  270. sie Attribute wären, die über <code>setAttribs()</code> und ähnliche gesetzt werden.
  271. </para>
  272. <para>
  273. Elemente werden, entweder in der Reihenfolge in der sie registriert wurden durchlaufen,
  274. oder, wenn ein Element ein 'order' Attribut enthält, in dieser Reihenfolge. Die
  275. Reihenfolge eines Elements kann, wie folgt, gesetzt werden:
  276. </para>
  277. <programlisting language="php"><![CDATA[
  278. $element->setOrder(10);
  279. ]]></programlisting>
  280. <para>
  281. Oder bei der Erstellung des Elements durch Übergabe als Option:
  282. </para>
  283. <programlisting language="php"><![CDATA[
  284. $form->addElement('text', 'username', array('order' => 10));
  285. ]]></programlisting>
  286. </sect2>
  287. <sect2 id="zend.form.quickstart.validate">
  288. <title>Prüfen, ob ein Formular gültig ist</title>
  289. <para>
  290. Nachdem ein Formular übermittelt wurde, muss diese geprüft werden, um zu sehen ob sie
  291. alle Prüfungen besteht. Jedes Element wird gegen die angegebenen Daten geprüft; wenn ein
  292. Schlüssel, der dem Elementnamen entspricht, nicht vorhanden ist, und das Element als
  293. benötigt markiert ist, werden die Prüfungen mit einem <constant>NULL</constant> Wert ausgeführt.
  294. </para>
  295. <para>
  296. Wo kommen die Daten her? Man kann <code>$_POST</code> oder <code>$_GET</code>
  297. verwenden, oder jede andere Datenquelle die man bei der Hand hat (Web Service Anfragen
  298. zum Beispiel):
  299. </para>
  300. <programlisting language="php"><![CDATA[
  301. if ($form->isValid($_POST)) {
  302. // erfolgreich!
  303. } else {
  304. // fehlgeschlagen!
  305. }
  306. ]]></programlisting>
  307. <para>
  308. Mit AJAX Anfragen kann man manchmal davon abweichen einzelne Elemente oder Gruppen von
  309. Elementen zu prüfen. <code>isValidPartial()</code> prüft einen Teil des Formulars.
  310. Anders, als <code>isValid()</code>, werden, wenn ein spezieller Schlüssel nicht
  311. vorhanden ist, Prüfungen für dieses spezielle Element nicht durchgeführt:
  312. </para>
  313. <programlisting language="php"><![CDATA[
  314. if ($form->isValidPartial($_POST)) {
  315. // Elemente hat alle Prüfungen bestanden
  316. } else {
  317. // Ein oder mehrere getestete Elemente haben die Prüfung nicht bestanden
  318. }
  319. ]]></programlisting>
  320. <para>
  321. Eine zusätzliche Methode, <code>processAjax()</code>, kann auch dafür verwendet werden,
  322. um Teilformen zu prüfen. Anders als <code>isValidPartial()</code>, gibt sie eine
  323. JSON-formatierten Zeichenkette zurück, die bei einem Fehler, die Fehlermeldungen
  324. enthält.
  325. </para>
  326. <para>
  327. Angenommen die Prüfungen sind durchgeführt worden, dann können jetzt die gefilterten
  328. Werte geholt werden:
  329. </para>
  330. <programlisting language="php"><![CDATA[
  331. $values = $form->getValues();
  332. ]]></programlisting>
  333. <para>
  334. Wenn an irgendeinem Punkt die ungefilterten Werte benötigt werden, kann man folgendes
  335. verwenden:
  336. </para>
  337. <programlisting language="php"><![CDATA[
  338. $unfiltered = $form->getUnfilteredValues();
  339. ]]></programlisting>
  340. </sect2>
  341. <sect2 id="zend.form.quickstart.errorstatus">
  342. <title>Fehlerstatus holen</title>
  343. <para>
  344. Das Formular hat die Prüfungen nicht bestanden? In den meisten Fällen, kann das Formular
  345. neu dargestellt werden, und Fehler werden angezeigt wenn Standardekoratoren verwendet
  346. werden:
  347. </para>
  348. <programlisting language="php"><![CDATA[
  349. if (!$form->isValid($_POST)) {
  350. echo $form;
  351. // oder dem View Obejekt zuordnen und eine View darstellen...
  352. $this->view->form = $form;
  353. return $this->render('form');
  354. }
  355. ]]></programlisting>
  356. <para>
  357. Wenn die Fehler inspiziert werden sollen, gibt es zwei Methoden.
  358. <code>getErrors()</code> gibt ein assoziatives Array von Elementnamen/Codes zurück
  359. (wobei Codes ein Array von Fehlercodes ist). <code>getMessages()</code> gibt ein
  360. assoziatives Array von Elementnamen/Nachrichten zurück (wobei Nachrichten ein
  361. assoziatives Array von Fehlercodes/Fehlernachrichten Paaren ist). Wenn ein gegebenes
  362. Element keinen Fehler hat, wird es dem Array nicht angefügt.
  363. </para>
  364. </sect2>
  365. <sect2 id="zend.form.quickstart.puttingtogether">
  366. <title>Alles zusammenfügen</title>
  367. <para>
  368. Bauen wir also ein Login Formular. Es benötigt Elemente die folgendes repräsentieren:
  369. </para>
  370. <itemizedlist>
  371. <listitem><para>username</para></listitem>
  372. <listitem><para>password</para></listitem>
  373. <listitem><para>submit</para></listitem>
  374. </itemizedlist>
  375. <para>
  376. Für unsere Zwecke nehmen wir an, dass ein gültiger Benutzername nur alphanumerische
  377. Zeichen enthalten soll und mit einem Buchstaben beginnt, eine Mindestlänge von 6 und
  378. eine Maximallänge von 20 Zeichen hat; er wird zu Kleinschreibung normalisiert.
  379. Passwörter müssen mindestens 6 Zeichen lang sein. Der submit Wert wird einfach ignoriert
  380. wenn wir fertig sind, er kann also ungeprüft bleiben.
  381. </para>
  382. <para>
  383. Wir verwenden die Stärke von <classname>Zend_Form</classname>'s Konfigurationsoptionen
  384. um die Form zu erstellen:
  385. </para>
  386. <programlisting language="php"><![CDATA[
  387. $form = new Zend_Form();
  388. $form->setAction('/user/login')
  389. ->setMethod('post');
  390. // Ein username Element erstellen und konfigurieren:
  391. $username = $form->createElement('text', 'username');
  392. $username->addValidator('alnum')
  393. ->addValidator('regex', false, array('/^[a-z]+/'))
  394. ->addValidator('stringLength', false, array(6, 20))
  395. ->setRequired(true)
  396. ->addFilter('StringToLower');
  397. // Ein Passwort Element erstellen und konfigurieren:
  398. $password = $form->createElement('password', 'password');
  399. $password->addValidator('StringLength', false, array(6))
  400. ->setRequired(true);
  401. // Elemente dem Formular hinzufügen:
  402. $form->addElement($username)
  403. ->addElement($password)
  404. // addElement() als Factory verwenden um den 'Login' Button zu erstellen:
  405. ->addElement('submit', 'login', array('label' => 'Login'));
  406. ]]></programlisting>
  407. <para>
  408. Als nächstes wird ein Controller erstellt der das Formular behandelt:
  409. </para>
  410. <programlisting language="php"><![CDATA[
  411. class UserController extends Zend_Controller_Action
  412. {
  413. public function getForm()
  414. {
  415. // Formular, wie oben beschrieben, erstellen
  416. return $form;
  417. }
  418. public function indexAction()
  419. {
  420. // user/form.phtml darstellen
  421. $this->view->form = $this->getForm();
  422. $this->render('form');
  423. }
  424. public function loginAction()
  425. {
  426. if (!$this->getRequest()->isPost()) {
  427. return $this->_forward('index');
  428. }
  429. $form = $this->getForm();
  430. if (!$form->isValid($_POST)) {
  431. // Fehlgeschlagene Prüfung; Form wieder anzeigen
  432. $this->view->form = $form;
  433. return $this->render('form');
  434. }
  435. $values = $form->getValues();
  436. // Jetzt versuchen zu Authentifizieren...
  437. }
  438. }
  439. ]]></programlisting>
  440. <para>
  441. Und ein View Skript für die Darstellung des Formulars:
  442. </para>
  443. <programlisting language="php"><![CDATA[
  444. <h2>Bitte anmelden:</h2>
  445. <?php echo $this->form ?>
  446. ]]></programlisting>
  447. <para>
  448. Wie man im Controller Code sieht, gibt es mehr Arbeit zu tun: Während die Übertragung
  449. gültig sein muss, kann es trotzdem notwendig sein, zum Beispiel, ein Authentifizierung
  450. mit Hilfe von <classname>Zend_Auth</classname> durchzuführen.
  451. </para>
  452. </sect2>
  453. <sect2 id="zend.form.quickstart.config">
  454. <title>Ein Zend_Config Objekt verwenden</title>
  455. <para>
  456. Alle <classname>Zend_Form</classname>'s sind konfigurierbar, indem
  457. <classname>Zend_Config</classname> verwendet wird; es kann entweder ein
  458. <classname>Zend_Config</classname> Objekt an den Kontruktor oder über
  459. <code>setConfig()</code> übergeben werden. Sehen wir uns an, wie das obige Formular
  460. erstellt werden kann, wenn wir eine INI Datei verwenden. Zuerst folgen wir den
  461. Notwendigkeiten und platzieren die Konfigurationen in Sektionen, die den Ort des
  462. Releases reflektieren, und fokusieren auf die 'development' Sektion. Als nächstes wird
  463. eine Sektion für den gegebenen Controller ('user') definiert und ein Schlüssel für das
  464. Formular ('login'):
  465. </para>
  466. <programlisting language="ini"><![CDATA[
  467. [development]
  468. ; general form metainformation
  469. user.login.action = "/user/login"
  470. user.login.method = "post"
  471. ; username element
  472. user.login.elements.username.type = "text"
  473. user.login.elements.username.options.validators.alnum.validator = "alnum"
  474. user.login.elements.username.options.validators.regex.validator = "regex"
  475. user.login.elements.username.options.validators.regex.options.pattern = "/^[a-z]/i"
  476. user.login.elements.username.options.validators.strlen.validator = "StringLength"
  477. user.login.elements.username.options.validators.strlen.options.min = "6"
  478. user.login.elements.username.options.validators.strlen.options.max = "20"
  479. user.login.elements.username.options.required = true
  480. user.login.elements.username.options.filters.lower.filter = "StringToLower"
  481. ; password element
  482. user.login.elements.password.type = "password"
  483. user.login.elements.password.options.validators.strlen.validator = "StringLength"
  484. user.login.elements.password.options.validators.strlen.options.min = "6"
  485. user.login.elements.password.options.required = true
  486. ; submit element
  487. user.login.elements.submit.type = "submit"
  488. ]]></programlisting>
  489. <para>
  490. Das kann dann an den Contruktor des Formulars übergeben werden:
  491. </para>
  492. <programlisting language="php"><![CDATA[
  493. $config = new Zend_Config_Ini($configFile, 'development');
  494. $form = new Zend_Form($config->user->login);
  495. ]]></programlisting>
  496. <para>
  497. und das komplette Formular wird definiert werden.
  498. </para>
  499. </sect2>
  500. <sect2 id="zend.form.quickstart.conclusion">
  501. <title>Schlussfolgerung</title>
  502. <para>
  503. Hoffentlich ist, mit dieser kleinen Anleitung der Weg klar, um die Leistung und
  504. Flexibilität von <classname>Zend_Form</classname> einzusetzen. Für detailiertere
  505. Informationen lesen Sie weiter!
  506. </para>
  507. </sect2>
  508. </sect1>
  509. <!--
  510. vim:se ts=4 sw=4 et:
  511. -->