Zend_Form-QuickStart.xml 23 KB

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