Zend_Form-Elements.xml 64 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 17133 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.form.elements">
  5. <title>Erstellen von Form Elementen mit Hilfe von Zend_Form_Element</title>
  6. <para>
  7. Ein Formular ist aus Elementen gemacht, die typischerweise mit einer HTML Form Eingabe
  8. korrespondieren. <classname>Zend_Form_Element</classname> kapselt einzelne Formularelemente
  9. mit den folgenden Bereichen die erfüllt werden sollen:
  10. </para>
  11. <itemizedlist>
  12. <listitem>
  13. <para>
  14. Prüfung (ist der übertragene Wert gültig?)
  15. </para>
  16. <itemizedlist>
  17. <listitem>
  18. <para>Fangen von Fehlercodes und Nachrichten von Prüfungen</para>
  19. </listitem>
  20. </itemizedlist>
  21. </listitem>
  22. <listitem><para>
  23. Filtern (wie wird das Element in Anführungsstriche gesetzt oder normalisiert bevor die
  24. Prüfung stattfinden und/oder für die Ausgabe?)
  25. </para></listitem>
  26. <listitem><para>
  27. Darstellung (wie wird das Element angezeigt?)
  28. </para></listitem>
  29. <listitem><para>
  30. Metadaten und Attribute (welche Informationen qualifizieren das Element näher?)
  31. </para></listitem>
  32. </itemizedlist>
  33. <para>
  34. Die Basisklasse, <classname>Zend_Form_Element</classname>, hat begründete Standardwerte für
  35. viele Fälle, aber es ist am besten die Klasse zu erweitern für oft verwendete speziell
  36. benötigte Elemente. Zusätzlich wird Zend Framework mit einer Anzahl an Standard
  37. XHTML Elementen ausgeliefert; über diese kann im
  38. <link linkend="zend.form.standardElements">Kapitel über Standard Elemente</link>
  39. nachgelesen werden.
  40. </para>
  41. <sect2 id="zend.form.elements.loaders">
  42. <title>Plugin Loader</title>
  43. <para>
  44. <classname>Zend_Form_Element</classname> verwendet
  45. <link linkend="zend.loader.pluginloader">Zend_Loader_PluginLoader</link> um es
  46. Entwicklern zu erlauben Orte für alternative Prüfungen, Filter und Dekoratoren zu
  47. definieren. Jeder hat seinen eigenen Plugin Loader assoziiert, und generelle
  48. Zugriffspunkte werden verwendet um jeden zu empfangen oder zu ändern.
  49. </para>
  50. <para>
  51. Die folgenden Ladetypen werden mit den verschiedenen Plugin Loader Methoden verwendet:
  52. 'validate', 'filter', und 'decorator'. Die Typnamen sind unabhängig von der
  53. Schreibweise.
  54. </para>
  55. <para>
  56. Die Methoden die für die Interaktion mit Plugin Loadern verwendet werden, sind die
  57. folgenden:
  58. </para>
  59. <itemizedlist>
  60. <listitem><para>
  61. <methodname>setPluginLoader($loader, $type)</methodname>: <code>$loader</code> ist
  62. das Plugin Loader Objekt selbst, während <code>$type</code> eine der oben
  63. spezifizierten Typen ist. Das setzt den Plugin Loader für den gegebenen Typ auf das
  64. neu spezifizierte Loader Objekt.
  65. </para></listitem>
  66. <listitem><para>
  67. <methodname>getPluginLoader($type)</methodname>: Empfängt den mit
  68. <code>$type</code> assoziierten Plugin Loader.
  69. </para></listitem>
  70. <listitem><para>
  71. <methodname>addPrefixPath($prefix, $path, $type = null)</methodname>: Fügt eine
  72. Präfix/Pfad Assoziation hinzu, Wenn <code>$type</code> null ist, wird versucht den
  73. Pfad zu allen Loadern hinzuzufügen durch anhängen des Präfix von jedem "_Validate",
  74. "_Filter", und "_Decorator"; und anhängen des Pfades an "Validate/", "Filter/",
  75. und "Decorator/". Wenn alle extra Formular Elementklassen unter einer üblichen
  76. Hirarchie stehen, ist das die bequemste Methode für das Setzen von grundsätzlichen
  77. Präfixen.
  78. </para></listitem>
  79. <listitem><para>
  80. <methodname>addPrefixPaths(array $spec)</methodname>: Erlaubt es viele Pfade auf
  81. einmal zu einem oder mehreren Plugin Loadern hinzuzufügen. Sie erwartet das jedes
  82. Arrayelement ein Array mit den Sclüsseln 'path', 'prefix' und 'type' ist.
  83. </para></listitem>
  84. </itemizedlist>
  85. <para>
  86. Eigene Prüfungen, Filter und Dekoratoren sind ein einfacher Weg um Funktionalität
  87. zwischen Forms zu teilen und eigene Funktionalitäten zu kapseln.
  88. </para>
  89. <example id="zend.form.elements.loaders.customLabel">
  90. <title>Eigenes Label</title>
  91. <para>
  92. Ein üblicher Verwendungszweck ist es Ersetzungen für Standardklassen anzubieten.
  93. Zum Beispiel wenn man eine andere Implementation des 'Label' Dekorators anbieten
  94. will -- zum Beispiel um immer einen Bindestrich anzufügen -- dann könnte man einen
  95. eigenen 'Label' Dekorator mit einem eigenen Klassenpräfix erstellen, und diesen
  96. zum eigenen Präfix Pfad hinzufügen.
  97. </para>
  98. <para>
  99. Beginnen wir mit einem eigenen Label Dekorator. Wir geben ihm den Klassenpräfix
  100. "My_Decorator", und die Klasse selbst wird in der Datei "My/Decorator/Label.php"
  101. sein.
  102. </para>
  103. <programlisting language="php"><![CDATA[
  104. class My_Decorator_Label extends Zend_Form_Decorator_Abstract
  105. {
  106. protected $_placement = 'PREPEND';
  107. public function render($content)
  108. {
  109. if (null === ($element = $this->getElement())) {
  110. return $content;
  111. }
  112. if (!method_exists($element, 'getLabel')) {
  113. return $content;
  114. }
  115. $label = $element->getLabel() . ':';
  116. if (null === ($view = $element->getView())) {
  117. return $this->renderLabel($content, $label);
  118. }
  119. $label = $view->formLabel($element->getName(), $label);
  120. return $this->renderLabel($content, $label);
  121. }
  122. public function renderLabel($content, $label)
  123. {
  124. $placement = $this->getPlacement();
  125. $separator = $this->getSeparator();
  126. switch ($placement) {
  127. case 'APPEND':
  128. return $content . $separator . $label;
  129. case 'PREPEND':
  130. default:
  131. return $label . $separator . $content;
  132. }
  133. }
  134. }
  135. ]]></programlisting>
  136. <para>
  137. Jetzt kann dem Element mitgeteilt werden diesen Plugin Pfad zu verwenden wenn
  138. nach Dekoratoren gesucht wird:
  139. </para>
  140. <programlisting language="php"><![CDATA[
  141. $element->addPrefixPath('My_Decorator', 'My/Decorator/', 'decorator');
  142. ]]></programlisting>
  143. <para>
  144. Alternativ kann das bei der Form gemacht werden um sicherzustellen das alle
  145. Dekoratore diesen Pfad verwenden:
  146. </para>
  147. <programlisting language="php"><![CDATA[
  148. $form->addElementPrefixPath('My_Decorator', 'My/Decorator/', 'decorator');
  149. ]]></programlisting>
  150. <para>
  151. Wird dieser Pfad hinzugefügt, wenn ein Dekorator hinzugefügt wird, wird der
  152. Pfad 'My/Decorator/' zuerst durchsucht um zu sehen ob der Dekorator dort existiert.
  153. Als Ergebnis wird 'My_Decorator_Label' jetzt verwendet wenn der 'Labe' Dekorator
  154. angefragt wird.
  155. </para>
  156. </example>
  157. </sect2>
  158. <sect2 id="zend.form.elements.filters">
  159. <title>Filter</title>
  160. <para>
  161. Es ist oft nützlich und/oder notwendig einige Normalisierungen an Eingaben vorzunehmen,
  162. bevor diese geprüft werden - zum Beispiel kann es gewünscht sein alles an HTML zu
  163. entfernen, aber die Prüfungen auf dem verbleibenden durchzuführen um sicherzustellen,
  164. dass die Übertragung gültig ist. Oder man will Leerzeichen bei Eingaben entfernen, damit
  165. eine StringLength Prüfung kein falsches "Korrekt" zurückgibt. Diese Operationen können
  166. durchgeführt werden indem <classname>Zend_Filter</classname> verwendet wird, und
  167. <classname>Zend_Form_Element</classname> unterstützt Filterketten, was es erlaubt
  168. mehrere, sequentielle Filter zu spezifizieren und anzupassen. Das Filtern geschieht
  169. während der Prüfung und wenn der Wert des Elements über
  170. <methodname>getValue()</methodname> geholt wird:
  171. </para>
  172. <programlisting language="php"><![CDATA[
  173. $filtered = $element->getValue();
  174. ]]></programlisting>
  175. <para>
  176. Filter können der Kette auf zwei Wegen hinzugefügt werden:
  177. </para>
  178. <itemizedlist>
  179. <listitem><para>
  180. Übergabe einer konkreten Filterinstanz
  181. </para></listitem>
  182. <listitem><para>
  183. Angabe eines Filternamens - entweder ein Kurzname oder ein voll qualifizierter
  184. Klassenname
  185. </para></listitem>
  186. </itemizedlist>
  187. <para>
  188. Sehen wir uns einige Beispiele an:
  189. </para>
  190. <programlisting language="php"><![CDATA[
  191. // Konkrete Filterinstanz:
  192. $element->addFilter(new Zend_Filter_Alnum());
  193. // Voll qualifizierter Klassenname:
  194. $element->addFilter('Zend_Filter_Alnum');
  195. // Kurzname des Filters:
  196. $element->addFilter('Alnum');
  197. $element->addFilter('alnum');
  198. ]]></programlisting>
  199. <para>
  200. Kurznamen sind typischerweise der Filtername ohne den Präfix. Im Standardfall bedeutet
  201. das keinen 'Zend_Filter_' Präfix. Zusätzlich muss der erste Buchstabe nicht
  202. großgeschrieben werden.
  203. </para>
  204. <note>
  205. <title>Eigene Filterklassen verwenden</title>
  206. <para>
  207. Wenn man sein eigenes Set an Filterklassen hat, kann man
  208. <classname>Zend_Form_Element</classname> mitteilen diese zu verwenden indem
  209. <methodname>addPrefixPath()</methodname> verwendet wird. Wenn man zum Beispiel
  210. eigene Filter unter dem 'My_Filter' Präfix hat, kann
  211. <classname>Zend_Form_Element</classname> dies auf dem folgenden Weg mitgeteilt
  212. werden:
  213. </para>
  214. <programlisting language="php"><![CDATA[
  215. $element->addPrefixPath('My_Filter', 'My/Filter/', 'filter');
  216. ]]></programlisting>
  217. <para>
  218. (Beachten Sie, dass das dritte Agument indiziert welcher Plugin Loader auf welcher
  219. Aktion durchgeführt werden soll.)
  220. </para>
  221. </note>
  222. <para>
  223. Wenn man zu irgendeiner Zeit den ungefilterten Wert benötigt, kann die
  224. <methodname>getUnfilteredValue()</methodname> Methode verwendet werden:
  225. </para>
  226. <programlisting language="php"><![CDATA[
  227. $unfiltered = $element->getUnfilteredValue();
  228. ]]></programlisting>
  229. <para>
  230. Für weitere Informationen über Filter, siehe die
  231. <link linkend="zend.filter.introduction">Dokumentation über Zend_Filter</link>.
  232. </para>
  233. <para>
  234. Die Methoden die mit Filtern assoziiert sind, beinhalten:
  235. </para>
  236. <itemizedlist>
  237. <listitem><para>
  238. <methodname>addFilter($nameOfFilter, array $options = null)</methodname>
  239. </para></listitem>
  240. <listitem><para>
  241. <methodname>addFilters(array $filters)</methodname>
  242. </para></listitem>
  243. <listitem><para>
  244. <methodname>setFilters(array $filters)</methodname> (Überschreibt alle Filter)
  245. </para></listitem>
  246. <listitem><para>
  247. <methodname>getFilter($name)</methodname> (Empfängt ein Filterobjekt durch seinen
  248. Namen)
  249. </para></listitem>
  250. <listitem><para>
  251. <methodname>getFilters()</methodname> (Empfängt alle Filter)
  252. </para></listitem>
  253. <listitem><para>
  254. <methodname>removeFilter($name)</methodname> (Entfernt einen Filter durch seinen
  255. Namen)
  256. </para></listitem>
  257. <listitem><para>
  258. <methodname>clearFilters()</methodname> (Entfernt alle Filter)
  259. </para></listitem>
  260. </itemizedlist>
  261. </sect2>
  262. <sect2 id="zend.form.elements.validators">
  263. <title>Prüfungen</title>
  264. <para>
  265. Wenn man das Sicherheits-Mantra von "Eingabe filtern, Ausgabe escapen" unterschreibt
  266. dann wird man die Eingabe des Formulars prüfen ("Eingabefilterung") wollen. In
  267. <classname>Zend_Form</classname> enthält jedes Element seine eigene Prüfkette, die aus
  268. <classname>Zend_Validate_*</classname> Prüfungen besteht.
  269. </para>
  270. <para>
  271. Prüfungen können der Kette auf zwei Wegen hinzugefügt werden:
  272. </para>
  273. <itemizedlist>
  274. <listitem><para>
  275. Übergabe einer konkreten Prüfinstanz
  276. </para></listitem>
  277. <listitem><para>
  278. Anbieten eines Prüfnamens - entweder ein Kurzname oder ein voll qualifizierter
  279. Klassenname
  280. </para></listitem>
  281. </itemizedlist>
  282. <para>
  283. Einige Beispiele:
  284. </para>
  285. <programlisting language="php"><![CDATA[
  286. // Konkrete Prüfinstanz:
  287. $element->addValidator(new Zend_Validate_Alnum());
  288. // Voll qualifizierter Klassenname:
  289. $element->addValidator('Zend_Validate_Alnum');
  290. // Kurzer Prüfname:
  291. $element->addValidator('Alnum');
  292. $element->addValidator('alnum');
  293. ]]></programlisting>
  294. <para>
  295. Kurznamen sind typischerweise der Prüfname ohne den Präfix. Im Standardfall bedeutet
  296. das, keinen 'Zend_Validate_' Präfix. Zusätzlich muss der erste Buchstabe nicht
  297. großgeschrieben werden.
  298. </para>
  299. <note>
  300. <title>Eigene Prüfklassen verwenden</title>
  301. <para>
  302. Wenn man sein eigenes Set an Prüfklassen hat, kann man
  303. <classname>Zend_Form_Element</classname> mitteilen diese zu verwenden indem
  304. <methodname>addPrefixPath()</methodname> verwendet wird. Wenn man zum Beispiel
  305. eigene Prüfungen unter dem 'My_Validator' Präfix hat, kann
  306. <classname>Zend_Form_Element</classname> dies auf dem folgenden Weg mitgeteilt
  307. werden:
  308. </para>
  309. <programlisting language="php"><![CDATA[
  310. $element->addPrefixPath('My_Validator', 'My/Validator/', 'validate');
  311. ]]></programlisting>
  312. <para>
  313. (Beachten Sie das das dritte Agument indiziert welcher Plugin Loader auf welcher
  314. Aktion durchgeführt werden soll.)
  315. </para>
  316. </note>
  317. <para>
  318. Wenn eine bestimmte Prüfung fehlschlägt, und die Ausführung von späteren Prüfungen
  319. verhindert werden soll, kann ein <constant>TRUE</constant> als zweiter Parameter übergeben
  320. werden:
  321. </para>
  322. <programlisting language="php"><![CDATA[
  323. $element->addValidator('alnum', true);
  324. ]]></programlisting>
  325. <para>
  326. Wenn ein Stringname verwendet wird, um eine Prüfung hinzuzufügen und die Prüfklasse
  327. Argumente in ihrem Konstruktor akzeptiert, können diese als dritter Parameter an
  328. <methodname>addValidator()</methodname> als Array übergeben werden:
  329. </para>
  330. <programlisting language="php"><![CDATA[
  331. $element->addValidator('StringLength', false, array(6, 20));
  332. ]]></programlisting>
  333. <para>
  334. Argumente die auf diesem Weg übergeben werden, sollten in der Reihenfolge sein in der
  335. sie im Konstruktor definiert sind. Das obige Beispiel instanziert die
  336. <classname>Zend_Validate_StringLenth</classname> Klasse mit den <code>$min</code> und
  337. <code>$max</code> Parametern:
  338. </para>
  339. <programlisting language="php"><![CDATA[
  340. $validator = new Zend_Validate_StringLength(6, 20);
  341. ]]></programlisting>
  342. <note>
  343. <title>Eigene Fehlermeldungen für Prüfungen anbieten</title>
  344. <para>
  345. Einige Entwickler wollen eigene Fehlermeldungen für eine Prüfung anbieten.
  346. <classname>Zend_Form_Element::addValidator()</classname>'s <code>$options</code>
  347. Argument erlaubt es das zu tun, indem der Schlüssel 'messages' angegeben wird und
  348. ein Array mit Schlüssel/Wert Paaren genutzt wird für das Setzen der
  349. Nachrichten Templates. Man muss die Fehlermeldungen der betreffenden Prüfung
  350. für die verschiedenen Fehlertypen von Prüfungen kennen.
  351. </para>
  352. <para>
  353. Eine bessere Option ist es <classname>Zend_Translate_Adapter</classname> in Formular
  354. zu verwenden. Fehlercodes werden automatisch dem Adapter durch den Standardmäßigen
  355. Fehlerdekorator übergeben; man kann durch die Erstellung von Übersetzungen
  356. eigene Fehlermeldungen für die verschiedenen Fehlercodes der Prüfung definieren.
  357. </para>
  358. </note>
  359. <para>
  360. Es können auch viele Prüfungen auf einmal gesetzt werden, indem
  361. <methodname>addValidators()</methodname> verwendet wird. Die grundsätzliche Verwendung
  362. ist es ein Array von Arrays zu übergeben, wobei jedes Array ein bis drei Werte enthält,
  363. die dem Konstruktor von <methodname>addValidator()</methodname> entsprechen:
  364. </para>
  365. <programlisting language="php"><![CDATA[
  366. $element->addValidators(array(
  367. array('NotEmpty', true),
  368. array('alnum'),
  369. array('stringLength', false, array(6, 20)),
  370. ));
  371. ]]></programlisting>
  372. <para>
  373. Wenn man wortreicher oder expliziter sein will, dann können die Arrayschlüssel
  374. 'validator', 'breakChainOnFailure', und 'options' verwendet werden:
  375. </para>
  376. <programlisting language="php"><![CDATA[
  377. $element->addValidators(array(
  378. array(
  379. 'validator' => 'NotEmpty',
  380. 'breakChainOnFailure' => true),
  381. array('validator' => 'alnum'),
  382. array(
  383. 'validator' => 'stringLength',
  384. 'options' => array(6, 20)),
  385. ));
  386. ]]></programlisting>
  387. <para>
  388. Die Verwendung ist gut für die Illustration wie Prüfungen in einer Konfigurationsdatei
  389. definiert werden können:
  390. </para>
  391. <programlisting language="ini"><![CDATA[
  392. element.validators.notempty.validator = "NotEmpty"
  393. element.validators.notempty.breakChainOnFailure = true
  394. element.validators.alnum.validator = "Alnum"
  395. element.validators.strlen.validator = "StringLength"
  396. element.validators.strlen.options.min = 6
  397. element.validators.strlen.options.max = 20
  398. ]]></programlisting>
  399. <para>
  400. Es ist zu beachten, dass jedes Element einen Schlüssel hat, egal ob er benötigt wird
  401. oder nicht; das ist eine Einschränkung bei der Verwendung von Konfigurationsdateien --
  402. aber es macht auch klar, für was die Argumente stehen. Es ist einfach zu beachten das
  403. jede Prüfungsoption in der richtigen Reihenfolge spezifiziert werden muss.
  404. </para>
  405. <para>
  406. Um ein Element zu prüfen, muss der Wert an <methodname>isValid()</methodname> übergeben
  407. werden:
  408. </para>
  409. <programlisting language="php"><![CDATA[
  410. if ($element->isValid($value)) {
  411. // gülig
  412. } else {
  413. // ungültig
  414. }
  415. ]]></programlisting>
  416. <note>
  417. <title>Die Prüfung findet an gefilterten Werte statt</title>
  418. <para>
  419. <classname>Zend_Form_Element::isValid()</classname> filtert Werte durch die
  420. angegebene Filterkette vor der Überprüfung. Siehe das
  421. <link linkend="zend.form.elements.filters">Kapitel über Filter</link> für
  422. weitere Informationen.
  423. </para>
  424. </note>
  425. <note>
  426. <title>Prüfungskontext</title>
  427. <para>
  428. <classname>Zend_Form_Element::isValid()</classname> unterstützt ein zusätzliches
  429. Argument <code>$context</code>. <classname>Zend_Form::isValid()</classname> übergibt
  430. ein komplettes Array von Daten die bearbeitet werden an <code>$context</code>, wenn
  431. ein Formular geprüft wird und <classname>Zend_Form_Element::isValid()</classname>
  432. übergibt es an jede Prüfung. Das bedeutet, dass man Prüfungen schreiben kann, die
  433. auf die Daten die an andere Formulare übergeben werden acht geben. Als Beispiel
  434. nehmen wir ein Anmeldeformular, welches die Felder für Passwort und Passwort
  435. Wiederholung hat; eine Prüfung würde sein, dass beide Felder den selben Wert
  436. beinhalten. So eine Prüfung könnte wie folgt aussehen:
  437. </para>
  438. <programlisting language="php"><![CDATA[
  439. class My_Validate_PasswordConfirmation extends Zend_Validate_Abstract
  440. {
  441. const NOT_MATCH = 'notMatch';
  442. protected $_messageTemplates = array(
  443. self::NOT_MATCH => 'Die Passwortüberprüfung war nicht erfolgreich'
  444. );
  445. public function isValid($value, $context = null)
  446. {
  447. $value = (string) $value;
  448. $this->_setValue($value);
  449. if (is_array($context)) {
  450. if (isset($context['password_confirm'])
  451. && ($value == $context['password_confirm']))
  452. {
  453. return true;
  454. }
  455. } elseif (is_string($context) && ($value == $context)) {
  456. return true;
  457. }
  458. $this->_error(self::NOT_MATCH);
  459. return false;
  460. }
  461. }
  462. ]]></programlisting>
  463. </note>
  464. <para>
  465. Prüfungen werden in der Reihenfolge ausgeführt. Jede Prüfung wird ausgeführt solange bis
  466. eine Prüfung die mit einem <constant>TRUE</constant> Wert für <code>breakChainOnFailure</code>
  467. bei Ihrer Prüfung fehlschlägt. Man sollte sichergehen, dass Prüfungen in einer
  468. begründeten Reihenfolge definiert werden.
  469. </para>
  470. <para>
  471. Nach einer fehlgeschlagenen Prüfung können Fehlercodes und Nachrichten von der
  472. Prüfkette empfangen werden:
  473. </para>
  474. <programlisting language="php"><![CDATA[
  475. $errors = $element->getErrors();
  476. $messages = $element->getMessages();
  477. ]]></programlisting>
  478. <para>
  479. (Achtung: zurückgegebene Fehlermeldungen sind ein assoziatives Array von
  480. Fehlercode/Fehlermeldung Paaren.)
  481. </para>
  482. <para>
  483. Zusätzlich zu Prüfungen, kann spezifiziert werden, dass ein Element benötigt wird,
  484. indem <methodname>setRequired(true)</methodname> verwendet wird. Standardmäßig ist
  485. dieses Flag <constant>FALSE</constant>, was bedeutet, dass die Prüfkette übersprungen
  486. wird, wenn kein Wert an <methodname>isValid()</methodname> übergeben wird. Dieses
  487. Verhalten kann auf verschiedene Weisen geändert werden:
  488. </para>
  489. <itemizedlist>
  490. <listitem>
  491. <para>
  492. Standardmäßig, wenn ein Element benötigt wird, ist auch ein Flag 'allowEmpty'
  493. <constant>TRUE</constant>. Das bedeutet, dass, wenn ein Wert evaluiert wird,
  494. der leer ist, und an <methodname>isValid()</methodname> übergeben wird, die
  495. Prüfung übersprungen wird. Dieses Flag kann gewechselt werden mit Hilfe der
  496. Zugriffsmethode <methodname>setAllowEmpty($flag)</methodname>; Wenn das Flag
  497. <constant>FALSE</constant> ist, und ein Wert übergeben wird, werden die
  498. Prüfungen trotzdem durchlaufen.
  499. </para>
  500. </listitem>
  501. <listitem>
  502. <para>
  503. Standardmäßig, wenn ein Element benötigt wird, es aber keine 'NotEmpty'
  504. Prüfung hat, wird <methodname>isValid()</methodname> eine an oberster Stelle im
  505. Stack platzieren. Das heißt, dass das Flag folgende semantische Bedeutung
  506. bekommt: Wenn kein Wert übergeben wird, wird die Übertragung sofort ungülig und
  507. der Benutzer wird informiert, was die anderen Prüfungen davon abhält,
  508. ausgeführt zu werden, auf Daten, von denen wir bereits wissen, dass sie
  509. ungültig sind.
  510. </para>
  511. <para>
  512. Wenn dieses Verhalten nicht gewünscht ist kann es durch die Übergabe eines
  513. <constant>FALSE</constant> Wert an
  514. <methodname>setAutoInsertNotEmptyValidator($flag)</methodname> ausgeschaltet
  515. werden; das verhindert, dass <methodname>isValid()</methodname> die 'NotEmpty'
  516. Prüfung in der Prüfkette platziert.
  517. </para>
  518. </listitem>
  519. </itemizedlist>
  520. <para>
  521. Für weitere Informationen über Prüfungen kann in die
  522. <link linkend="zend.validate.introduction">Zend_Validate Dokumentation</link>
  523. gesehen werden.
  524. </para>
  525. <note>
  526. <title>Verwenden von Zend_Form_Elements als generell-eingesetzte Prüfung</title>
  527. <para>
  528. <classname>Zend_Form_Element</classname> implementiert
  529. <classname>Zend_Validate_Interface</classname> was bedeutet das ein Element auch als
  530. Prüfung füreinander verwendet werden kann, bezüglich nicht-Formular Prüfketten.
  531. </para>
  532. </note>
  533. <para>
  534. Die mit der Prüfung assoziierten Methoden sind:
  535. </para>
  536. <itemizedlist>
  537. <listitem><para>
  538. <methodname>setRequired($flag)</methodname> und
  539. <methodname>isRequired()</methodname> erlauben es den Status des 'required'
  540. Flag zu setzen und zu empfangen. Wenn der Wert auf <constant>TRUE</constant>
  541. gesetzt wird, erzwingt dieses Flag, dass das Element, in den Daten die von
  542. <classname>Zend_Form</classname> bearbeitet werden, vorhanden ist.
  543. </para></listitem>
  544. <listitem><para>
  545. <methodname>setAllowEmpty($flag)</methodname> und
  546. <methodname>getAllowEmpty()</methodname> erlauben es das Verhalten von
  547. optionalen Elementen (z.B. Elementen in denen das 'required' Flag
  548. <constant>FALSE</constant> ist) zu ändern. Wenn das 'allowEmpty' Flag
  549. <constant>TRUE</constant> ist, werden leere Werte nicht an die Prüfkette übergeben.
  550. </para></listitem>
  551. <listitem><para>
  552. <methodname>setAutoInsertNotEmptyValidator($flag)</methodname> erlaubt es zu
  553. definieren ob eine 'NotEmpty' Prüfung der Prüfkette vorangestellt wird wenn das
  554. Element benötigt wird. Standardmäßig ist dieses Flag <constant>TRUE</constant>.
  555. </para></listitem>
  556. <listitem><para>
  557. <code>addValidator($nameOrValidator, $breakChainOnFailure = false, array $options =
  558. null)</code>
  559. </para></listitem>
  560. <listitem><para>
  561. <methodname>addValidators(array $validators)</methodname>
  562. </para></listitem>
  563. <listitem><para>
  564. <methodname>setValidators(array $validators)</methodname> (Überschreibt alle
  565. Prüfer)
  566. </para></listitem>
  567. <listitem><para>
  568. <methodname>getValidator($name)</methodname> (Empfängt ein Prüfobjekt durch seinen
  569. Namen)
  570. </para></listitem>
  571. <listitem><para>
  572. <methodname>getValidators()</methodname> (Empfängt alle Prüfer)
  573. </para></listitem>
  574. <listitem><para>
  575. <methodname>removeValidator($name)</methodname> (Entfernt einen Prüfer durch seinen
  576. Namen)
  577. </para></listitem>
  578. <listitem><para>
  579. <methodname>clearValidators()</methodname> (Entfernt alle Prüfer)
  580. </para></listitem>
  581. </itemizedlist>
  582. <sect3 id="zend.form.elements.validators.errors">
  583. <title>Eigene Fehlermeldungen</title>
  584. <para>
  585. Von Zeit zu Zeit ist es gewünscht ein oder mehrere spezielle Fehlermeldungen zu
  586. spezifizieren, die statt der Fehlermeldungen verwendet werden sollen, die von den
  587. Validatoren verwendet werden, die dem Element angehängt sind. Zusätzlich will man
  588. von Zeit zu Zeit ein Element selbst als ungültig markieren. Ab Version 1.6.0 des
  589. Zend Frameworks ist diese Funktionalität über die folgenden Methoden möglich.
  590. </para>
  591. <itemizedlist>
  592. <listitem><para>
  593. <methodname>addErrorMessage($message)</methodname>: Fügt eine Fehlermeldung
  594. hinzu, die bei Formular-Überprüfungs-Fehlern angezeigt wird. Sie kann mehr als
  595. einmal aufgerufen werden, und neue Meldungen werden dem Stack angehängt.
  596. </para></listitem>
  597. <listitem><para>
  598. <methodname>addErrorMessages(array $messages)</methodname>: Fügt mehrere
  599. Fehlermeldungen hinzu, die bei Formular-Überprüfungs-Fehlern angezeigt werden.
  600. </para></listitem>
  601. <listitem><para>
  602. <methodname>setErrorMessages(array $messages)</methodname>: Fügt mehrere
  603. Fehlermeldungen hinzu, die bei Formular-Überprüfungs-Fehlern angezeigt werden,
  604. und überschreibt alle vorher gesetzten Fehlermeldungen.
  605. </para></listitem>
  606. <listitem><para>
  607. <methodname>getErrorMessages()</methodname>: Empfängt eine Liste von
  608. selbstdefinierten Fehlermeldungen, die vorher definiert wurden.
  609. </para></listitem>
  610. <listitem><para>
  611. <methodname>clearErrorMessages()</methodname>: Entfernt alle eigenen
  612. Fehlermeldungen, die vorher definiert wurden.
  613. </para></listitem>
  614. <listitem><para>
  615. <methodname>markAsError()</methodname>: Markiert das Element, wie, wenn die
  616. Überprüfung fehlgeschlagen wäre.
  617. </para></listitem>
  618. <listitem><para>
  619. <methodname>hasErrors()</methodname>: Erkennt, ob ein Element eine Überprüfung
  620. nicht bestanden hat oder, ob es als ungültig markiert wurde.
  621. </para></listitem>
  622. <listitem><para>
  623. <methodname>addError($message)</methodname>: Fügt einen Fehler zum eigenen
  624. Stack der Fehlermeldungen hinzu und markiert das Element als ungültig.
  625. </para></listitem>
  626. <listitem><para>
  627. <methodname>addErrors(array $messages)</methodname>: Fügt mehrere Nachrichten
  628. zum eigenen Stack der Fehlermeldungen hinzu und markiert das Element als
  629. ungültig.
  630. </para></listitem>
  631. <listitem><para>
  632. <methodname>setErrors(array $messages)</methodname>: Überschreibt den eigenen
  633. Stack der Fehlermeldungen mit den angegebenen Meldungen und markiert das
  634. Element als ungültig.
  635. </para></listitem>
  636. </itemizedlist>
  637. <para>
  638. Alle Fehler die auf diesem Weg gesetzt werden, können übersetzt werden. Zusätzlich
  639. kann der Platzhalter "%value%" eingefügt werden um den Wert des Elements zu
  640. repräsentieren; dieser aktuelle Wert des Element wird eingefügt wenn die
  641. Fehlermeldung empfangen wird.
  642. </para>
  643. </sect3>
  644. </sect2>
  645. <sect2 id="zend.form.elements.decorators">
  646. <title>Dekoratoren</title>
  647. <para>
  648. Ein möglicher Schmerzpunkt für viele Webentwickler, ist die Erstellung von XHTML
  649. Formularen selbst. Für jedes Element muss der Entwickler das Markup für das Element
  650. selbst erstellen, typischerweise ein Label und, wenn sie nett zu den Benutzern sind, das
  651. Markup für die Anzeige von Fehlermeldungen von Prüfungen. Je mehr Elemente auf einer
  652. Seite sind, desto weniger trivial wird diese Aufgabe.
  653. </para>
  654. <para>
  655. <classname>Zend_Form_Element</classname> versucht dieses Problem durch die Verwendung
  656. von "Dekoratoren" zu lösen. Dekoratoren sind Klassen die Zugriff auf das Element
  657. haben und eine Methode zur Darstellung des Inhalts bieten. Für weitere Informationen
  658. darüber wie Dekoratoren arbeiten, kann im Kapitel über
  659. <link linkend="zend.form.decorators">Zend_Form_Decorator</link> eingesehen werden.
  660. </para>
  661. <para>
  662. Die von <classname>Zend_Form_Element</classname> verwendeten Standarddekoratoren sind:
  663. </para>
  664. <itemizedlist>
  665. <listitem><para>
  666. <emphasis>ViewHelper</emphasis>: Spezifiziert einen View Helfer der verwendet wird,
  667. um das Element darzustellen. Das 'helper' Attribut des Elements kann verwendet
  668. werden, um zu spezifizieren welcher View Helfer verwendet werden soll. Standardmäßig
  669. spezifiziert <classname>Zend_Form_Element</classname> den 'formText' View Helfer,
  670. aber individuelle Unterklassen spezifizieren unterschiedliche Helfer.
  671. </para></listitem>
  672. <listitem><para>
  673. <emphasis>Errors</emphasis>: Fügt Fehlermeldungen an das Element an, indem es
  674. <classname>Zend_View_Helper_FormErrors</classname> verwendet. Wenn keine vorhanden
  675. sind, wird nichts hinzugefügt.
  676. </para></listitem>
  677. <listitem><para>
  678. <emphasis>Description</emphasis>: Fügt dem Element eine Beschreibung hinzu. Wenn
  679. keine vorhanden ist, wird nichts angehängt. Standardmäßig wird die Beschreibung in
  680. einem &lt;p&gt; Tag dargestellt mit einer CSS Klasse namens 'description'.
  681. </para></listitem>
  682. <listitem><para>
  683. <emphasis>HtmlTag</emphasis>: Umschliesst das Element und Fehler in einem HTML
  684. &lt;dd&gt; Tag.
  685. </para></listitem>
  686. <listitem><para>
  687. <emphasis>Label</emphasis>: Stellt ein Label vor das Element, indem es
  688. <classname>Zend_View_Helper_FormLabel</classname> verwendet, und umschliesst es in
  689. einem &lt;dt&gt; Tag. Wenn kein Label angegeben wurde, wird nur das &lt;dt&gt; Tag
  690. dargestellt.
  691. </para></listitem>
  692. </itemizedlist>
  693. <note>
  694. <title>Standard Dekoratoren müssen nicht geladen werden</title>
  695. <para>
  696. Standardmäßig werden die Standarddekoratoren während der Initialisierung des Objekts
  697. geladen. Das kann durch die Übergabe der 'disableLoadDefaultDecorators' Option an
  698. den Konstruktor ausgeschaltet werden:
  699. </para>
  700. <programlisting language="php"><![CDATA[
  701. $element = new Zend_Form_Element('foo',
  702. array('disableLoadDefaultDecorators' =>
  703. true)
  704. );
  705. ]]></programlisting>
  706. <para>
  707. Diese Option kann mit jeder anderen Option gemischt werden die übergeben wird,
  708. sowohl als Array Option oder in einem <classname>Zend_Config</classname> Objekt.
  709. </para>
  710. </note>
  711. <para>
  712. Da die Reihenfolge, in der die Dekoratoren registriert werden, von Bedeutung ist -- der
  713. zuerst registrierte Dekorator wird als erstes ausgeführt -- muss man sicherstellen, dass
  714. eigene Dekoratoren in der richtigen Reihenfolge registriert werden, oder sicherstellen,
  715. dass die Platzierungs-Optionen in einem ausgewogenen Weg gesetzt werden. Um ein Beispiel
  716. zu geben, ist hier ein Code der den Standarddekorator registriert:
  717. </para>
  718. <programlisting language="php"><![CDATA[
  719. $this->addDecorators(array(
  720. array('ViewHelper'),
  721. array('Errors'),
  722. array('Description', array('tag' => 'p', 'class' => 'description')),
  723. array('HtmlTag', array('tag' => 'dd')),
  724. array('Label', array('tag' => 'dt')),
  725. ));
  726. ]]></programlisting>
  727. <para>
  728. Der anfängliche Inhalt wird vom 'ViewHelper' Dekorator erstellt, welche das Formular
  729. Element selbst erstellt. Als nächstes fängt der 'Errors' Dekorator Fehlermeldungen vom
  730. Element und, wenn welche vorhanden sind, übergibt er sie an den 'FormErrors' View Helfer
  731. zur Darstellung. Wenn eine Beschreibung vorhanden ist, wird der 'Description' Dekorator
  732. einen Paragraph der Klasse 'description' anhängen, der den beschreibenden Text für den
  733. betreffenden Inhalt enthält. Der nächste Dekorator, 'HtmlTag', umschliesst das Element
  734. und die Fehler in ein HTML &lt;dd&gt; Tag. Letztendlich, empfängt der letzte Dekorator,
  735. 'label' das Label des Elements und übergibt es an den 'FormLabel' View Helfer, und
  736. umschliesst es in einen HTML &lt;dt&gt; Tag; der Wert wird dem Inhalt standardmäßig
  737. vorangestellt. Die resultierende Ausgabe sieht grundsätzlich wie folgt aus:
  738. </para>
  739. <programlisting language="html"><![CDATA[
  740. <dt><label for="foo" class="optional">Foo</label></dt>
  741. <dd>
  742. <input type="text" name="foo" id="foo" value="123" />
  743. <ul class="errors">
  744. <li>"123" ist kein alphanummerischer Wert</li>
  745. </ul>
  746. <p class="description">
  747. Das ist etwas beschreibender Text betreffend dem Element.
  748. </p>
  749. </dd>
  750. ]]></programlisting>
  751. <para>
  752. Für weitere Informationen über Dekoratoren gibt es das
  753. <link linkend="zend.form.decorators">Kapitel über Zend_Form_Decorator</link>.
  754. </para>
  755. <note>
  756. <title>Mehrere Dekoratoren des gleichen Typs verwenden</title>
  757. <para>
  758. Intern verwendet <classname>Zend_Form_Element</classname> eine Dekoratorklasse als
  759. Mechanismus für das Nachschauen wenn Dekoratore empfangen werden. Als Ergebnis,
  760. können mehrere Dekratoren nicht zur gleichen Zeit registriert werden; nachgeordnete
  761. Dekoratoren überschreiben jene, die vorher existiert haben.
  762. </para>
  763. <para>
  764. Um das zu umgehen, können <emphasis>Aliase</emphasis> verwendet werden. Statt der
  765. Übergabe eines Dekorators oder Dekoratornamens als erstes Argument an
  766. <methodname>addDecorator()</methodname>, kann ein Array mit einem einzelnen Element
  767. übergeben werden, mit dem Alias der auf das Dekoratorobjekt oder -namen zeigt:
  768. </para>
  769. <programlisting language="php"><![CDATA[
  770. // Alias zu 'FooBar':
  771. $element->addDecorator(array('FooBar' => 'HtmlTag'),
  772. array('tag' => 'div'));
  773. // Und es später erhalten:
  774. $decorator = $element->getDecorator('FooBar');
  775. ]]></programlisting>
  776. <para>
  777. In den <methodname>addDecorators()</methodname> und
  778. <methodname>setDecorators()</methodname> Methoden muss die 'decorator' Option im
  779. Array übergeben werden, welche den Dekorator repräsentiert:
  780. </para>
  781. <programlisting language="php"><![CDATA[
  782. // Zwei 'HtmlTag' Dekoratore hinzufügen, einen Alias auf 'FooBar' setzen:
  783. $element->addDecorators(
  784. array('HtmlTag', array('tag' => 'div')),
  785. array(
  786. 'decorator' => array('FooBar' => 'HtmlTag'),
  787. 'options' => array('tag' => 'dd')
  788. ),
  789. );
  790. // Und sie später empfangen:
  791. $htmlTag = $element->getDecorator('HtmlTag');
  792. $fooBar = $element->getDecorator('FooBar');
  793. ]]></programlisting>
  794. </note>
  795. <para>
  796. Die folgenden Methoden sind mit Dekoratoren assoziiert:
  797. </para>
  798. <itemizedlist>
  799. <listitem><para>
  800. <methodname>addDecorator($nameOrDecorator, array $options = null)</methodname>
  801. </para></listitem>
  802. <listitem><para>
  803. <methodname>addDecorators(array $decorators)</methodname>
  804. </para></listitem>
  805. <listitem><para>
  806. <methodname>setDecorators(array $decorators)</methodname> (Überschreibt alle
  807. Dekoratoren)
  808. </para></listitem>
  809. <listitem><para>
  810. <methodname>getDecorator($name)</methodname> (Empfängt ein Dekoratorobjekt durch
  811. seinen Namen)
  812. </para></listitem>
  813. <listitem><para>
  814. <methodname>getDecorators()</methodname> (Empfängt alle Dekoratoren)
  815. </para></listitem>
  816. <listitem><para>
  817. <methodname>removeDecorator($name)</methodname> (Entfernt einen Dekorator durch
  818. seinen Namen)
  819. </para></listitem>
  820. <listitem><para>
  821. <methodname>clearDecorators()</methodname> (Entfernt alle Dekoratoren)
  822. </para></listitem>
  823. </itemizedlist>
  824. <para>
  825. <classname>Zend_Form_Element</classname> verwendet auch Überladung um die Darstellung
  826. von speziellen Dekoratoren zu erlauben. <methodname>__call()</methodname> interagiert
  827. mit Methoden auf mit dem Text 'render' anfangen und verwendet den Rest des
  828. Methodennamens dazu um nach einen Dekorator zu suchen; wenn er gefunden wird, wird er
  829. diesen <emphasis>einzelnen</emphasis> Dekorator darstellen. Jedes Argument das dem
  830. Methodenaufruf übergeben wird, wird als Inhalt für die Übergabe an die
  831. <methodname>render()</methodname> Methode des Dekorators verwendet. Als Beispiel:
  832. </para>
  833. <programlisting language="php"><![CDATA[
  834. // Stellt nur den ViewHelper Dekorator dar:
  835. echo $element->renderViewHelper();
  836. // Nur den HtmlTag Dekorator darstellen, und Inhalt übergeben:
  837. echo $element->renderHtmlTag("Das ist der Inhalt des HTML Tags");
  838. ]]></programlisting>
  839. <para>
  840. Wenn der Dekorator nicht existiert, wird eine Exception geworfen.
  841. </para>
  842. </sect2>
  843. <sect2 id="zend.form.elements.metadata">
  844. <title>Metadaten und Attribute</title>
  845. <para>
  846. <classname>Zend_Form_Element</classname> behandelt eine Vielzahl von Attributen und
  847. Metadaten des Elements. Basisattribute sind:
  848. </para>
  849. <itemizedlist>
  850. <listitem><para>
  851. <emphasis>name</emphasis>: Der Name des Elements. Verwendet die Zugriffsmethoden
  852. <methodname>setName()</methodname> und <methodname>getName()</methodname>.
  853. </para></listitem>
  854. <listitem><para>
  855. <emphasis>label</emphasis>: Das Label des Elements. Verwendet die Zugriffsmethoden
  856. <methodname>setLabel()</methodname> und <methodname>getLabel()</methodname>.
  857. </para></listitem>
  858. <listitem><para>
  859. <emphasis>order</emphasis>: Der Index bei dem ein Element im Formular erscheinen
  860. soll. Verwendet die Zugriffsmethoden <methodname>setOrder()</methodname> und
  861. <methodname>getOrder()</methodname>.
  862. </para></listitem>
  863. <listitem><para>
  864. <emphasis>value</emphasis>: Der aktuelle Wert des Elements. Verwendet die
  865. Zugriffsmethoden <methodname>setValue()</methodname> und
  866. <methodname>getValue()</methodname>.
  867. </para></listitem>
  868. <listitem><para>
  869. <emphasis>description</emphasis>: Eine Beschreibung des Elements; wird oft
  870. verwendet um Tooltips oder Javascript mäßige Hinweise anzubieten die den Zweck
  871. des Elements beschreiben. Verwendet die Zugriffsmethoden
  872. <methodname>setDescription()</methodname> und
  873. <methodname>getDescription()</methodname>.
  874. </para></listitem>
  875. <listitem><para>
  876. <emphasis>required</emphasis>: Ein Flag, das anzeigt ob ein Element benötigt wird
  877. wenn eine Prüfung des Formulars durchgeführt wird, oder nicht. Verwendet die
  878. Zugriffsmethoden <methodname>setRequired()</methodname> und
  879. <methodname>getRequired()</methodname>. Dieses Flag ist standardmäßig
  880. <constant>FALSE</constant>.
  881. </para></listitem>
  882. <listitem><para>
  883. <emphasis>allowEmpty</emphasis>: Ein Flag, das indiziert ob ein nicht benötigtes
  884. (optionales) Element versuchen soll leere Werte zu prüfen. Wenn es
  885. <constant>TRUE</constant> ist, und das 'required' Flag <constant>FALSE</constant>,
  886. dann werden leere Werte nicht an die Prüfkette übergeben, und es wird
  887. <constant>TRUE</constant> angenommen. Verwendet die Zugriffsmethoden
  888. <methodname>setAllowEmpty()</methodname> und
  889. <methodname>getAllowEmpty()</methodname>. Dieses Flag ist standardmäßig
  890. <constant>TRUE</constant>.
  891. </para></listitem>
  892. <listitem><para>
  893. <emphasis>autoInsertNotEmptyValidator</emphasis>: Ein Flag, das indiziert, ob eine
  894. 'NotEmpty' Prüfung eingefügt werden soll, wenn das Element benötigt wird, oder
  895. nicht. Standardmäßig ist dieses Flag <constant>TRUE</constant>. Das Flag kann mit
  896. <methodname>setAutoInsertNotEmptyValidator($flag)</methodname> gesetzt und der Wert
  897. mit <methodname>autoInsertNotEmptyValidator()</methodname> ermittelt werden.
  898. </para></listitem>
  899. </itemizedlist>
  900. <para>
  901. Formular Elemente können zusätzliche Metadaten benötigen. Für XHTML Form Elemente zum
  902. Beispiel, kann es gewünscht sein, Attribute wie die Klasse oder die Id zu spezifizieren.
  903. Für die Durchführung gibt es ein Set von Zugriffsmethoden:
  904. </para>
  905. <itemizedlist>
  906. <listitem><para>
  907. <emphasis>setAttrib($name, $value)</emphasis>: Fügt ein Attribut hinzu
  908. </para></listitem>
  909. <listitem><para>
  910. <emphasis>setAttribs(array $attribs)</emphasis>: Wie addAttribs(), aber
  911. überschreibend
  912. </para></listitem>
  913. <listitem><para>
  914. <emphasis>getAttrib($name)</emphasis>: Empfägt einen einzelnen Attributwert
  915. </para></listitem>
  916. <listitem><para>
  917. <emphasis>getAttribs()</emphasis>: Empfängt alle Attribute als Schlüssel/Wert Paare
  918. </para></listitem>
  919. </itemizedlist>
  920. <para>
  921. Die meiste Zeit kann auf sie, trotzdem, einfach als Objekteigenschaften zugegriffen
  922. werden, da <classname>Zend_Form_Element</classname> das Überladen realisiert und den
  923. Zugriff zu ihnen erlaubt:
  924. </para>
  925. <programlisting language="php"><![CDATA[
  926. // Gleichbedeutend mit $element->setAttrib('class', 'text'):
  927. $element->class = 'text;
  928. ]]></programlisting>
  929. <para>
  930. Standardmäßig werden alle Attribute, die an den View Helfer übergeben werden, auch vom
  931. Element während der Darstellung verwendet, und als HTML Attribute des Element Tags
  932. dargestellt.
  933. </para>
  934. </sect2>
  935. <sect2 id="zend.form.elements.standard">
  936. <title>Standard Elemente</title>
  937. <para>
  938. <classname>Zend_Form</classname> wird mit einer Anzahl an Standardelementen
  939. ausgeliefert; lesen Sie das Kapitel über
  940. <link linkend="zend.form.standardElements">Standard Elemente</link> für vollständige
  941. Details.
  942. </para>
  943. </sect2>
  944. <sect2 id="zend.form.elements.methods">
  945. <title>Zend_Form_Element Methoden</title>
  946. <para>
  947. <classname>Zend_Form_Element</classname> hat viele, viele Methoden. Was folgt, ist eine
  948. kurze Zusammenfassung ihrer Signatur - gruppiert nach Typ:
  949. </para>
  950. <itemizedlist>
  951. <listitem><para>Konfiguration:</para>
  952. <itemizedlist>
  953. <listitem>
  954. <para><methodname>setOptions(array $options)</methodname></para>
  955. </listitem>
  956. <listitem>
  957. <para><methodname>setConfig(Zend_Config $config)</methodname></para>
  958. </listitem>
  959. </itemizedlist>
  960. </listitem>
  961. <listitem><para>I18n:</para>
  962. <itemizedlist>
  963. <listitem>
  964. <para>
  965. <methodname>setTranslator(Zend_Translate_Adapter $translator =
  966. null)</methodname>
  967. </para>
  968. </listitem>
  969. <listitem><para><methodname>getTranslator()</methodname></para></listitem>
  970. <listitem>
  971. <para><methodname>setDisableTranslator($flag)</methodname></para>
  972. </listitem>
  973. <listitem>
  974. <para><methodname>translatorIsDisabled()</methodname></para>
  975. </listitem>
  976. </itemizedlist>
  977. </listitem>
  978. <listitem><para>Eigenschaften:</para>
  979. <itemizedlist>
  980. <listitem><para><methodname>setName($name)</methodname></para></listitem>
  981. <listitem><para><methodname>getName()</methodname></para></listitem>
  982. <listitem><para><methodname>setValue($value)</methodname></para></listitem>
  983. <listitem><para><methodname>getValue()</methodname></para></listitem>
  984. <listitem><para><methodname>getUnfilteredValue()</methodname></para></listitem>
  985. <listitem><para><methodname>setLabel($label)</methodname></para></listitem>
  986. <listitem><para><methodname>getLabel()</methodname></para></listitem>
  987. <listitem>
  988. <para><methodname>setDescription($description)</methodname></para>
  989. </listitem>
  990. <listitem><para><methodname>getDescription()</methodname></para></listitem>
  991. <listitem><para><methodname>setOrder($order)</methodname></para></listitem>
  992. <listitem><para><methodname>getOrder()</methodname></para></listitem>
  993. <listitem><para><methodname>setRequired($flag)</methodname></para></listitem>
  994. <listitem><para><methodname>getRequired()</methodname></para></listitem>
  995. <listitem><para><methodname>setAllowEmpty($flag)</methodname></para></listitem>
  996. <listitem><para><methodname>getAllowEmpty()</methodname></para></listitem>
  997. <listitem>
  998. <para>
  999. <methodname>setAutoInsertNotEmptyValidator($flag)</methodname>
  1000. </para>
  1001. </listitem>
  1002. <listitem>
  1003. <para><methodname>autoInsertNotEmptyValidator()</methodname></para>
  1004. </listitem>
  1005. <listitem><para><methodname>setIgnore($flag)</methodname></para></listitem>
  1006. <listitem><para><methodname>getIgnore()</methodname></para></listitem>
  1007. <listitem><para><methodname>getType()</methodname></para></listitem>
  1008. <listitem>
  1009. <para><methodname>setAttrib($name, $value)</methodname></para>
  1010. </listitem>
  1011. <listitem>
  1012. <para><methodname>setAttribs(array $attribs)</methodname></para>
  1013. </listitem>
  1014. <listitem><para><methodname>getAttrib($name)</methodname></para></listitem>
  1015. <listitem><para><methodname>getAttribs()</methodname></para></listitem>
  1016. </itemizedlist>
  1017. </listitem>
  1018. <listitem><para>Plugin Loader und Pfade:</para>
  1019. <itemizedlist>
  1020. <listitem>
  1021. <para>
  1022. <code>setPluginLoader(Zend_Loader_PluginLoader_Interface $loader,
  1023. $type)</code>
  1024. </para>
  1025. </listitem>
  1026. <listitem>
  1027. <para><methodname>getPluginLoader($type)</methodname></para>
  1028. </listitem>
  1029. <listitem>
  1030. <para>
  1031. <methodname>addPrefixPath($prefix, $path, $type = null)</methodname>
  1032. </para>
  1033. </listitem>
  1034. <listitem>
  1035. <para><methodname>addPrefixPaths(array $spec)</methodname></para>
  1036. </listitem>
  1037. </itemizedlist>
  1038. </listitem>
  1039. <listitem><para>Prüfung:</para>
  1040. <itemizedlist>
  1041. <listitem>
  1042. <para>
  1043. <code>addValidator($validator, $breakChainOnFailure = false, $options =
  1044. array())</code>
  1045. </para>
  1046. </listitem>
  1047. <listitem>
  1048. <para><methodname>addValidators(array $validators)</methodname></para>
  1049. </listitem>
  1050. <listitem>
  1051. <para><methodname>setValidators(array $validators)</methodname></para>
  1052. </listitem>
  1053. <listitem><para><methodname>getValidator($name)</methodname></para></listitem>
  1054. <listitem><para><methodname>getValidators()</methodname></para></listitem>
  1055. <listitem>
  1056. <para><methodname>removeValidator($name)</methodname></para>
  1057. </listitem>
  1058. <listitem><para><methodname>clearValidators()</methodname></para></listitem>
  1059. <listitem>
  1060. <para><methodname>isValid($value, $context = null)</methodname></para>
  1061. </listitem>
  1062. <listitem><para><methodname>getErrors()</methodname></para></listitem>
  1063. <listitem><para><methodname>getMessages()</methodname></para></listitem>
  1064. </itemizedlist>
  1065. </listitem>
  1066. <listitem><para>Filter:</para>
  1067. <itemizedlist>
  1068. <listitem>
  1069. <para>
  1070. <methodname>addFilter($filter, $options = array())</methodname>
  1071. </para>
  1072. </listitem>
  1073. <listitem>
  1074. <para><methodname>addFilters(array $filters)</methodname></para>
  1075. </listitem>
  1076. <listitem>
  1077. <para><methodname>setFilters(array $filters)</methodname></para>
  1078. </listitem>
  1079. <listitem><para><methodname>getFilter($name)</methodname></para></listitem>
  1080. <listitem><para><methodname>getFilters()</methodname></para></listitem>
  1081. <listitem><para><methodname>removeFilter($name)</methodname></para></listitem>
  1082. <listitem><para><methodname>clearFilters()</methodname></para></listitem>
  1083. </itemizedlist>
  1084. </listitem>
  1085. <listitem><para>Darstellung:</para>
  1086. <itemizedlist>
  1087. <listitem>
  1088. <para>
  1089. <methodname>setView(Zend_View_Interface $view = null)</methodname>
  1090. </para>
  1091. </listitem>
  1092. <listitem><para><methodname>getView()</methodname></para></listitem>
  1093. <listitem>
  1094. <para>
  1095. <methodname>addDecorator($decorator, $options = null)</methodname>
  1096. </para>
  1097. </listitem>
  1098. <listitem>
  1099. <para><methodname>addDecorators(array $decorators)</methodname></para>
  1100. </listitem>
  1101. <listitem>
  1102. <para><methodname>setDecorators(array $decorators)</methodname></para>
  1103. </listitem>
  1104. <listitem><para><methodname>getDecorator($name)</methodname></para></listitem>
  1105. <listitem><para><methodname>getDecorators()</methodname></para></listitem>
  1106. <listitem>
  1107. <para><methodname>removeDecorator($name)</methodname></para>
  1108. </listitem>
  1109. <listitem><para><methodname>clearDecorators()</methodname></para></listitem>
  1110. <listitem>
  1111. <para>
  1112. <methodname>render(Zend_View_Interface $view = null)</methodname>
  1113. </para>
  1114. </listitem>
  1115. </itemizedlist>
  1116. </listitem>
  1117. </itemizedlist>
  1118. </sect2>
  1119. <sect2 id="zend.form.elements.config">
  1120. <title>Konfiguration</title>
  1121. <para>
  1122. Der Konstruktor von <classname>Zend_Form_Element</classname> akzeptiert entweder einen
  1123. Array von Optionen oder ein <classname>Zend_Config</classname> Objekt das Optionen
  1124. enthält, und es kann auch durch Verwendung von <methodname>setOptions()</methodname>
  1125. oder <methodname>setConfig()</methodname> konfiguriert werden. Generell, werden die
  1126. Schlüssel wie folgt benannt:
  1127. </para>
  1128. <itemizedlist>
  1129. <listitem><para>
  1130. Wenn 'set' + Schlüssel auf eine <classname>Zend_Form_Element</classname> Methode
  1131. zeigt, dann wird der angebotene Wert zu dieser Methode übermittelt.
  1132. </para></listitem>
  1133. <listitem><para>
  1134. Andernfalls wird der Wert verwendet um ein Attribut zu setzen.
  1135. </para></listitem>
  1136. </itemizedlist>
  1137. <para>
  1138. Ausnahmen zu dieser Regel sind die folgenden:
  1139. </para>
  1140. <itemizedlist>
  1141. <listitem><para>
  1142. <code>prefixPath</code> wird an <methodname>addPrefixPaths()</methodname> übergeben
  1143. </para></listitem>
  1144. <listitem>
  1145. <para>
  1146. Die folgenden Setzer können nicht auf diesem Weg gesetzt werden:
  1147. </para>
  1148. <itemizedlist>
  1149. <listitem><para>
  1150. <code>setAttrib</code> (über <code>setAttribs</code>
  1151. <emphasis>wird</emphasis> es funktionieren)
  1152. </para></listitem>
  1153. <listitem><para><code>setConfig</code></para></listitem>
  1154. <listitem><para><code>setOptions</code></para></listitem>
  1155. <listitem><para><code>setPluginLoader</code></para></listitem>
  1156. <listitem><para><code>setTranslator</code></para></listitem>
  1157. <listitem><para><code>setView</code></para></listitem>
  1158. </itemizedlist>
  1159. </listitem>
  1160. </itemizedlist>
  1161. <para>
  1162. Als Beispiel ist hier eine Konfigurationsdatei die eine Konfiguration für jeden
  1163. Typ von konfigurierbaren Daten übergibt:
  1164. </para>
  1165. <programlisting language="ini"><![CDATA[
  1166. [element]
  1167. name = "foo"
  1168. value = "foobar"
  1169. label = "Foo:"
  1170. order = 10
  1171. required = true
  1172. allowEmpty = false
  1173. autoInsertNotEmptyValidator = true
  1174. description = "Foo Elemente sind für Beispiele"
  1175. ignore = false
  1176. attribs.id = "foo"
  1177. attribs.class = "element"
  1178. ; Setzt das 'onclick' Attribut
  1179. onclick = "autoComplete(this, '/form/autocomplete/element')"
  1180. prefixPaths.decorator.prefix = "My_Decorator"
  1181. prefixPaths.decorator.path = "My/Decorator/"
  1182. disableTranslator = 0
  1183. validators.required.validator = "NotEmpty"
  1184. validators.required.breakChainOnFailure = true
  1185. validators.alpha.validator = "alpha"
  1186. validators.regex.validator = "regex"
  1187. validators.regex.options.pattern = "/^[A-F].*/$"
  1188. filters.ucase.filter = "StringToUpper"
  1189. decorators.element.decorator = "ViewHelper"
  1190. decorators.element.options.helper = "FormText"
  1191. decorators.label.decorator = "Label"
  1192. ]]></programlisting>
  1193. </sect2>
  1194. <sect2 id="zend.form.elements.custom">
  1195. <title>Eigene Elemente</title>
  1196. <para>
  1197. Es können eigene Elemente durch die Erweiterung der
  1198. <classname>Zend_Form_Element</classname> Klasse erstellt werden. Übliche Gründe hierfür
  1199. sind:
  1200. </para>
  1201. <itemizedlist>
  1202. <listitem><para>
  1203. Elemente, die eine gemeinsame Prüfung und/oder Filter teilen
  1204. </para></listitem>
  1205. <listitem><para>
  1206. Elemente die eine eigene Dekoratoren Funktionalität haben
  1207. </para></listitem>
  1208. </itemizedlist>
  1209. <para>
  1210. Es gibt zwei Methoden die typischerweise verwendet werden, um ein Element zu erweitern:
  1211. <methodname>init()</methodname>, was verwendet werden kannm um eine eigene
  1212. Initialisierungs-Logik zum Element hinzuzufügen, und
  1213. <methodname>loadDefaultDecorators()</methodname>, was verwendet werden kann um eine
  1214. Liste von Standard Dekoratoren zu setzen, die vom Element verwendet werden sollen.
  1215. </para>
  1216. <para>
  1217. Als Beispiel nehmen wir an, dass alle Text Elemente eines Formulars die erstellt werden
  1218. mit <code>StringTrim</code> gefiltert werden müssen, mit einem gemeinsamen Regulären
  1219. Ausdruck und das ein eigener Dekorator 'My_Decorator_TextItem' verwendet werden soll,
  1220. der für die Darstellung von ihnen erstellt wurde; zusätzlich gibt es eine Anzahl an
  1221. Standardattributen, wie 'size', 'maxLength', und 'class', die spezifiziert werden
  1222. sollen. So ein Element könnte wie folgt definiert werden:
  1223. </para>
  1224. <programlisting language="php"><![CDATA[
  1225. class My_Element_Text extends Zend_Form_Element
  1226. {
  1227. public function init()
  1228. {
  1229. $this->addPrefixPath('My_Decorator', 'My/Decorator/', 'decorator')
  1230. ->addFilters('StringTrim')
  1231. ->addValidator('Regex', false, array('/^[a-z0-9]{6,}$/i'))
  1232. ->addDecorator('TextItem')
  1233. ->setAttrib('size', 30)
  1234. ->setAttrib('maxLength', 45)
  1235. ->setAttrib('class', 'text');
  1236. }
  1237. }
  1238. ]]></programlisting>
  1239. <para>
  1240. Man könnte dann das Formular Objekt über den Präfix Pfad für diese Elemente informieren,
  1241. und die Erstellung der Elemente beginnen:
  1242. </para>
  1243. <programlisting language="php"><![CDATA[
  1244. $form->addPrefixPath('My_Element', 'My/Element/', 'element')
  1245. ->addElement('text', 'foo');
  1246. ]]></programlisting>
  1247. <para>
  1248. Das 'foo' Element wird vom Typ <classname>My_Element_Text</classname> sein, und dem
  1249. beschriebenen Verhalten entsprechen.
  1250. </para>
  1251. <para>
  1252. Eine andere Methode, die man überschreiben sollte, wenn
  1253. <classname>Zend_Form_Element</classname> erweitert wird, ist die
  1254. <methodname>loadDefaultDecorators()</methodname> Methode. Diese Methode lädt fallweise
  1255. ein Set von Standarddekoratoren für das Element; es kann gewünscht sein, eigene
  1256. Dekoratoren in der erweiterten Klasse zu verwenden:
  1257. </para>
  1258. <programlisting language="php"><![CDATA[
  1259. class My_Element_Text extends Zend_Form_Element
  1260. {
  1261. public function loadDefaultDecorators()
  1262. {
  1263. $this->addDecorator('ViewHelper')
  1264. ->addDecorator('DisplayError')
  1265. ->addDecorator('Label')
  1266. ->addDecorator('HtmlTag',
  1267. array('tag' => 'div', 'class' => 'element'));
  1268. }
  1269. }
  1270. ]]></programlisting>
  1271. <para>
  1272. Es gibt viele Wege, Elemente anzupassen; man sollte sicherstellen die API Dokumentation
  1273. von <classname>Zend_Form_Element</classname> zu lesen um alle vorhandenen Methoden zu
  1274. kennen.
  1275. </para>
  1276. </sect2>
  1277. </sect1>
  1278. <!--
  1279. vim:se ts=4 sw=4 tw=80 et:
  1280. -->