Zend_Form-StandardElements.xml 35 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 14978 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.form.standardElements">
  5. <title>Standard Form Elemente die mit dem With Zend Framework ausgeliefert werden</title>
  6. <para>
  7. Zend Framework wird mit konkreten Element Klassen ausgeliefert die die meisten HTML
  8. Form Elemente abdecken. Die meisten spezifizieren einfach einen speziellen View Helfer
  9. zur Verwendung wenn das Element dekoriert wird, aber einige bieten zusätzliche
  10. Funktionalitäten an. Nachfolgend ist eine Liste aller solcher Klassen, sowie eine
  11. Beschreibung der Funktionalität die Sie anbieten.
  12. </para>
  13. <sect2 id="zend.form.standardElements.button">
  14. <title>Zend_Form_Element_Button</title>
  15. <para>
  16. Wird für die Erstellung von HTML Button Elementen verwendet wobei
  17. <classname>Zend_Form_Element_Button</classname>
  18. <link linkend="zend.form.standardElements.submit">Zend_Form_Element_Submit</link>
  19. erweitert, und seine eigene Funktionalität hinzufügt. Sie spezifiziert den 'formButton'
  20. View Helfer für die Dekoration.
  21. </para>
  22. <para>
  23. Wie das Submit Element, verwendet es das Label des Elements als den Elementwert für
  24. Darstellungszwecke; in anderen Worten, um den Text des Buttons zu setzen, muß der
  25. Wert des Elements gesetzt werden. Das Label wird übersetzt wenn ein
  26. Übersetzungsadapter vorhanden ist.
  27. </para>
  28. <para>
  29. Weil das Label als Teil des Elements verwendet wird, verwendet das Button Element nur
  30. den <link linkend="zend.form.standardDecorators.viewHelper">ViewHelper</link> und den
  31. <link linkend="zend.form.standardDecorators.dtDdWrapper">DtDdWrapper</link> Dekorator.
  32. </para>
  33. <para>
  34. Nach der Veröffentlichung oder Prüfung einer Form, kann geprüft werden ob der gegebene
  35. Button geklickt wurd indem die <code>isChecked()</code> Methode verwendet wird.
  36. </para>
  37. </sect2>
  38. <sect2 id="zend.form.standardElements.captcha">
  39. <title>Zend_Form_Element_Captcha</title>
  40. <para>
  41. CAPTCHAs werden verwendet um automatische Übermittlung von Formularen durch Bots und andere
  42. automatische Prozesse zu verhindern.
  43. </para>
  44. <para>
  45. Das Captcha Formularelement erlaubt es den
  46. <link linkend="zend.captcha.adapters">Zend_Captcha Adapter</link> der als Formular CAPTCHA
  47. verwendet werden soll anzupassen. Er setzt dann diesen Adapter als Prüfung für das Objekt,
  48. und verwendet den Captcha Dekorator für die Darstellung (welche den CAPTCHA Adapter aufruft).
  49. </para>
  50. <para>
  51. Adapter können alle Adapter in <classname>Zend_Captcha</classname> sein, sowie jeder eigene Adapter
  52. der irgendwo anders definiert wurde. Um das z uerlauben, kann ein zusätzlicher Schlüssel für
  53. den Plugin Ladetyp, 'CAPTCHA' oder 'captcha' übergeben werden, wenn der Plugin Loader Präfixpfad
  54. spezifiziert wird:
  55. </para>
  56. <programlisting role="php"><![CDATA[
  57. $element->addPrefixPath('My_Captcha', 'My/Captcha/', 'captcha');
  58. ]]>
  59. </programlisting>
  60. <para>
  61. Captcha's können dann durch Verwendung der <code>setCaptcha()</code> Methode registriert werden,
  62. welche entweder eine konkrete CAPTCHA Instanz, oder den Kurznamen des CAPTCHA Adapters nimmt:
  63. </para>
  64. <programlisting role="php"><![CDATA[
  65. // Konkrete Instanz:
  66. $element->setCaptcha(new Zend_Captcha_Figlet());
  67. // Verwendung von Kurznamen:
  68. $element->setCaptcha('Dumb');
  69. ]]>
  70. </programlisting>
  71. <para>
  72. Wenn das Element über die Konfiguration geladen werden soll, kann entweder der Schlüssel
  73. 'captcha' mit einem Array das den Schlüssel 'captcha' enthält spezifiziert werden, oder beide
  74. Schlüssel 'captcha' und 'captchaOptions':
  75. </para>
  76. <programlisting role="php"><![CDATA[
  77. // Verwendung eines einzelnen captcha Schlüssels:
  78. $element = new Zend_Form_Element_Captcha('foo', array(
  79. 'label' => "Bitte verifizieren Sie das Sie menschlich sind",
  80. 'captcha' => array(
  81. 'captcha' => 'Figlet',
  82. 'wordLen' => 6,
  83. 'timeout' => 300,
  84. ),
  85. ));
  86. // Verwendung von beiden, captcha und captchaOptions:
  87. $element = new Zend_Form_Element_Captcha('foo', array(
  88. 'label' => "Bitte verifizieren Sie das Sie menschlich sind",
  89. 'captcha' => 'Figlet',
  90. 'captchaOptions' => array(
  91. 'captcha' => 'Figlet',
  92. 'wordLen' => 6,
  93. 'timeout' => 300,
  94. ),
  95. ));
  96. ]]>
  97. </programlisting>
  98. <para>
  99. Der verwendete Dekorator wird durch die Abfrage des Captcha Adapters erkannt. Standardmäßig wird
  100. der <link linkend="zend.form.standardDecorators.captcha">Captcha Dekorator</link> verwendet,
  101. aber ein Adapter kann einen anderen über die <code>getDecorator()</code> Methode spezifizieren.
  102. </para>
  103. <para>
  104. Wie beschrieben, fungiert der Captcha Adapter selbst als Prüfnug für das Element. Zusätzlich
  105. wird die NotEmpty Prüfung nicht verwendet, und das Element wird als benötigt markiert. In
  106. den meisten Fällen sollte sonst nichts anderes mehr notwendig sein um das Captcha im
  107. eigenen Formular zu haben.
  108. </para>
  109. </sect2>
  110. <sect2 id="zend.form.standardElements.checkbox">
  111. <title>Zend_Form_Element_Checkbox</title>
  112. <para>
  113. HTML Checkboxen erlauben es spezifische Werte zurückzugeben, arbeiten aber
  114. grundsätzlich als Boolean. Wenn Sie angehackt sind, wird der Wert der Checkbox übertragen. Wenn Sie
  115. nicht angehackt sind, wird nichts übertragen. Intern erzwingt
  116. <classname>Zend_Form_Element_Checkbox</classname> diesen Status.
  117. </para>
  118. <para>
  119. Standardmäßg ist der angehackte Wert '1', und der nicht angehackte Wert '0'. Dieser
  120. Wert kann spezifiziert werden indem die <code>setCheckedValue()</code> und
  121. <code>setUncheckedValue()</code> Zugriffsmethoden verwendet werden. Intern wird,
  122. jedesmal wenn der Wert gesetzt wird, wenn der angebotene Wert dem angehackten Wert
  123. entspricht, er gesetzt, aber jeder andere Wert bewirkt das der nicht angehackte Wert
  124. gesetzt wird.
  125. </para>
  126. <para>
  127. Zusätzlich setzt, das Setzen des Werte, die <code>checked</code> Eigenschaft der
  128. Checkbox. Das kann abgefragt werden indem <code>isChecked()</code> verwendet wird oder
  129. einfach auf die Eigenschaft zugegriffen wird. Das Verwenden der
  130. <code>setChecked($flag)</code> Methode setzt beides, den Status des Flags sowie den
  131. entsprechenden gecheckten oder nicht gecheckten Wert im Element. Bitte verwenden Sie
  132. diese Methode wenn der gecheckte Status eines Checkbox Elements gesetzt wird um
  133. sicherzustellen das der Wert richtig gesetzt wird.
  134. </para>
  135. <para>
  136. <classname>Zend_Form_Element_Checkbox</classname> verwendet den 'formCheckbox' View Helfer. Der
  137. angehackte Wert wird immer verwendet um Sie zu veröffentlichen.
  138. </para>
  139. </sect2>
  140. <sect2 id="zend.form.standardElements.file">
  141. <title>Zend_Form_Element_File</title>
  142. <para>
  143. Das File Formularelement bietet einen Mechanismus um File Upload-felder in eigenen Formularen
  144. zu Unterstützen. Es verwendet intern
  145. <link linkend="zend.file.transfer.introduction">Zend_File_Transfer</link> um diese Funktionalität
  146. zu bieten, und den <code>FormFile</code> Viewhelfer sowie den <code>File</code> Decorator um das
  147. Formularelement anzuzeigen.
  148. </para>
  149. <para>
  150. Standardmäßig verwendet es den <code>Http</code> Transferadapter, welcher das <code>$_FILES</code>
  151. Array prüft und es erlaubt Prüfungen und Filter hinzuzufügen. Prüfungen und Filter die dem
  152. Formularelement hinzugefügt werden, werden dem Transferadapter hinzugefügt.
  153. </para>
  154. <example id="zend.form.standardElements.file.usage">
  155. <title>Verwendung des File Formularelements</title>
  156. <para>
  157. Die obige Erklärung der Verwendung des File Formularelements mag geheimnisvoll erscheinen,
  158. aber die aktuelle Verwendung ist relativ trivial:
  159. </para>
  160. <programlisting role="php"><![CDATA[
  161. $element = new Zend_Form_Element_File('foo');
  162. $element->setLabel('Ein Bild hochladen:')
  163. ->setDestination('/var/www/upload');
  164. // Nur 1 Datei sicherstellen
  165. $element->addValidator('Count', false, 1);
  166. // Maximal 100k
  167. $element->addValidator('Size', false, 102400);
  168. // Nur JPEG, PNG, und GIFs
  169. $element->addValidator('Extension', false, 'jpg,png,gif');
  170. $form->addElement($element, 'foo');
  171. ]]>
  172. </programlisting>
  173. <para>
  174. Man sollte auch den richtigen Encodingtyp sicherstellen in dem das Formular angeboten wird.
  175. Das kann getan werden indem das 'enctype' Attribut des Formulars gesetzt wird:
  176. </para>
  177. <programlisting role="php"><![CDATA[
  178. $form->setAttrib('enctype', 'multipart/form-data');
  179. ]]>
  180. </programlisting>
  181. <para>
  182. Nachdem das Formular erfolgreich geprüft wurde, muß die Datei empfangen werden um Sie an Ihrem
  183. endgültigen Ziel zu speichern indem <code>receive()</code> verwendet wird. Zusätzlich kann man
  184. das endgültige Ziel ermittelt werden indem <code>getFileName()</code> verwendet wird:
  185. </para>
  186. <programlisting role="php"><![CDATA[
  187. if (!$form->isValid) {
  188. print "Uh oh... Prüfungsfehler";
  189. }
  190. if (!$form->foo->receive()) {
  191. print "Fehler beim Empfangen der Datei";
  192. }
  193. $location = $form->foo->getFileName();
  194. ]]>
  195. </programlisting>
  196. </example>
  197. <note>
  198. <title>Standardmäßige Ablage von Uploads</title>
  199. <para>
  200. Standardmäßig werden Dateien in das Temp Verzeichnis des Systems hochgeladen.
  201. </para>
  202. </note>
  203. <note>
  204. <title>Datei Werte</title>
  205. <para>
  206. In HTTP hat das File Element keinen Wert. Aus diesem Grund, und aus Gründen der Sicherheit
  207. erhält gibt <code>getValue()</code> nur den Dateinamen der hochgeladenen Datei zurück und
  208. nicht den kompletten Pfad. Wenn man die kompletten Informationen benötigt kann
  209. <code>getFileName()</code> aufgerufen werden, welches sowohl den Pfad als auch den Namen
  210. der Datei zurückgibt.
  211. </para>
  212. </note>
  213. <para>
  214. Standardmäßig wird die Datei automatisch empfangen wenn man <code>getValues()</code>
  215. auf dem Formular aufruft. Der Grund hinter diesem Verhalten ist, das die Datei selbst
  216. der Wert des File Elements ist.
  217. </para>
  218. <programlisting role="php"><![CDATA[
  219. $form->getValues();
  220. ]]>
  221. </programlisting>
  222. <note>
  223. <para>
  224. Deshalb hat ein weiterer Aufruf von <code>receive()</code> nach dem Aufruf von
  225. <code>getValues()</code> keinen Effekt. Auch die Erstellung einer Instanz von
  226. <classname>Zend_File_Transfer</classname> wird keinen Effekt haben da es keine weitere
  227. Datei zum Empfangen gibt.
  228. </para>
  229. </note>
  230. <para>
  231. Trotzdem kann es manchmal gewünscht sein <code>getValues()</code> aufzurufen ohne das
  232. die Datei empfangen wird. Man kann dies erreichen indem
  233. <code>setValueDisabled(true)</code> aufgerufen wird. Um den aktuellen Wert dieses
  234. Flags zu erhalten kann man <code>isValueDisabled()</code> aufrufen.
  235. </para>
  236. <example id="zend.form.standardElements.file.retrievement">
  237. <title>Datei explizit empfangen</title>
  238. <para>
  239. Zuerst <code>setValueDisabled(true)</code> aufrufen.
  240. </para>
  241. <programlisting role="php"><![CDATA[
  242. $element = new Zend_Form_Element_File('foo');
  243. $element->setLabel('Ein Bild hochladen:')
  244. ->setDestination('/var/www/upload')
  245. ->setValueDisabled(true);
  246. ]]>
  247. </programlisting>
  248. <para>
  249. Jetzt wird die Datei nicht mehr empfangen wenn man <code>getValues()</code>
  250. aufruft. Man muß also <code>receive()</code> vom Datei Element, oder einer
  251. Instanz von <classname>Zend_File_Transfer</classname> selbst aufrufen.
  252. </para>
  253. <programlisting role="php"><![CDATA[
  254. $values = $form->getValues();
  255. if ($form->isValid($form->getPost())) {
  256. if (!$form->foo->receive()) {
  257. print "Upload Fehler";
  258. }
  259. }
  260. ]]>
  261. </programlisting>
  262. </example>
  263. <para>
  264. Es gibt verschiedene Stati von hochgeladenen Dateien welche mit den folgenden Optionen
  265. geprüft werden können:
  266. </para>
  267. <itemizedlist>
  268. <listitem>
  269. <para>
  270. <code>isUploaded()</code>: Prüft ob das Dateielement hochgeladen wurde oder nicht.
  271. </para>
  272. </listitem>
  273. <listitem>
  274. <para>
  275. <code>isReceived()</code>: Prüft ob das Dateielement bereits empfangen wurde.
  276. </para>
  277. </listitem>
  278. <listitem>
  279. <para>
  280. <code>isFiltered()</code>: Prüft ob die Filter bereits dem Dateielement
  281. angehängt wurden oder nicht.
  282. </para>
  283. </listitem>
  284. </itemizedlist>
  285. <example id="zend.form.standardElements.file.isuploaded">
  286. <title>Prüfen ob eine optionale Datei hochgeladen wurde</title>
  287. <programlisting role="php"><![CDATA[
  288. $element = new Zend_Form_Element_File('foo');
  289. $element->setLabel('Ein Bild hochladen:')
  290. ->setDestination('/var/www/upload')
  291. ->setRequired(false);
  292. $element->addValidator('Size', false, 102400);
  293. $form->addElement($element, 'foo');
  294. // Das foo Dateielement is optional, aber wenn es angegeben wurde, gehe hier herein
  295. if ($form->foo->isUploaded()) {
  296. // Die foo Datei ist angegeben... mach was
  297. }
  298. ]]>
  299. </programlisting>
  300. </example>
  301. <para>
  302. <classname>Zend_Form_Element_File</classname> unterstützt auch mehrere Dateien. Durch den Aufruf der
  303. <code>setMultiFile($count)</code> Methode kann die Anzahl an File Elementen die man erstellen
  304. will festgelegt werden. Das verhindert das die selben Einstellungen mehrere Male durchgeführt
  305. werden müssen.
  306. </para>
  307. <example id="zend.form.standardElements.file.multiusage">
  308. <title>Mehrere Dateien setzen</title>
  309. <para>
  310. Die Erstellung eines Multifile Elements ist das gleiche wie das Erstellen eines einzelnen
  311. Elements. Man muß nur <code>setMultiFile()</code> aufrufen nachdem das Element erstellt wurde:
  312. </para>
  313. <programlisting role="php"><![CDATA[
  314. $element = new Zend_Form_Element_File('foo');
  315. $element->setLabel('Ein Bild hochladen:')
  316. ->setDestination('/var/www/upload');
  317. // Mindestens 1 und maximal 3 Dateien sicherstellen
  318. $element->addValidator('Count', false, array('min' => 1, 'max' => 3));
  319. // Auf 100k limitieren
  320. $element->addValidator('Size', false, 102400);
  321. // Nur JPEG, PNG, und GIFs
  322. $element->addValidator('Extension', false, 'jpg,png,gif');
  323. // 3 identische Dateielemente definieren
  324. $element->setMultiFile(3);
  325. $form->addElement($element, 'foo');
  326. ]]>
  327. </programlisting>
  328. <para>
  329. In der View erhält man nun 3 identische File Upload Elemente welche alle die gleichen
  330. Einstellungen verwenden. Um die Multifile Anzahl zu erhalten kann man einfach
  331. <code>getMultiFile()</code> aufrufen.
  332. </para>
  333. </example>
  334. <note>
  335. <title>File Elemente in Subformularen</title>
  336. <para>
  337. Wenn File Elemente in Subformularen verwendet werden muß man eindeutige Namen setzen.
  338. Wenn man zum Beispiel ein File Element in Subform1 "file" benennt, muß es in Subform2
  339. einen anderen Namen erhalten.
  340. </para>
  341. <para>
  342. Sobald es 2 identisch benannte File Elemente gibt, wird das zweite Element entweder
  343. nicht dargestellt oder nicht übertragen.
  344. </para>
  345. </note>
  346. <para>
  347. Um die Größe der Datei zu begrenzen, die vom Client hochgeladen wird, kann die maximale
  348. Dateigröße spezifiziert werden indem die <code>MAX_FILE_SIZE</code> Option im Formular
  349. gesetzt wird. Sobald der Wert, durch die Verwendung der <code>setMaxFileSize($size)</code>
  350. Methode, gesetzt ist, wird er mit dem File Element dargestellt.
  351. </para>
  352. <programlisting role="php"><![CDATA[
  353. $element = new Zend_Form_Element_File('foo');
  354. $element->setLabel('Ein Bild hochladen:')
  355. ->setDestination('/var/www/upload')
  356. ->addValidator('Size', false, 102400) // Limitiert auf 100k
  357. ->setMaxFileSize(102400); // Limitiert die Dateigröße auf der Clientseite
  358. $form->addElement($element, 'foo');
  359. ]]>
  360. </programlisting>
  361. <note>
  362. <title>MaxFileSize mit mehreren File Elementen</title>
  363. <para>
  364. Wenn mehrere File Elemente im Formular verwendet werden sollte man <code>MAX_FILE_SIZE</code>
  365. nur einmal setzen. Wird es nochmals gesetzt überschreibt es den vorherigen Wert.
  366. </para>
  367. <para>
  368. Beachte, das das auch der Fall ist wenn man mehrere Formulare verwendet.
  369. </para>
  370. </note>
  371. </sect2>
  372. <sect2 id="zend.form.standardElements.hidden">
  373. <title>Zend_Form_Element_Hidden</title>
  374. <para>
  375. Versteckte Elemente fügen Daten ein die übertragen werden sollen, welche der Benutzer
  376. aber nicht manipulieren soll. <classname>Zend_Form_Element_Hidden</classname> ermöglicht das
  377. mit dem 'formHidden' View Helfers.
  378. </para>
  379. </sect2>
  380. <sect2 id="zend.form.standardElements.hash">
  381. <title>Zend_Form_Element_Hash</title>
  382. <para>
  383. Dieses Element bietet Schutz vor CSRF Attacken auf Forms, und stellt sicher das die
  384. Daten die übertragen werden von der Benutzersession stammen die die Form erstellt hat
  385. und nicht durch ein bösartiges Skript. Sicherheit wird ermöglicht durch das hinzufügen
  386. eines Hash Elements zur form und dessen Prüfung wenn die Form übermittelt wird.
  387. </para>
  388. <para>
  389. Der Name des Hash Elements sollte einmalig sein. Wir emphehlen die Verwendung der
  390. <literal>salt</literal> Option für das Element- damit zwei Hashes mit dem gleichen
  391. Namen und unterschiedlichen Salts nicht kollidieren:
  392. </para>
  393. <programlisting role="php"><![CDATA[
  394. $form->addElement('hash', 'no_csrf_foo', array('salt' => 'unique'));
  395. ]]>
  396. </programlisting>
  397. <para>
  398. Das Salt kann später gesetzt werden durch Verwendung der <code>setSalt($salt)</code>
  399. Methode.
  400. </para>
  401. <para>
  402. Intern speichert das Element einen eindeutigen Identifikator indem es
  403. <classname>Zend_Session_Namespace</classname> verwendet, und danach bei der Übertragung checkt
  404. (es wird geprüft das die TTL nicht abgelaufen ist). Die 'Identical' Prüfung wird
  405. Internally, the element stores a unique identifier using
  406. <classname>Zend_Session_Namespace</classname>, and checks for it at
  407. submission (checking that the TTL has not expired). The 'Identical'
  408. validator is then used to ensure the submitted hash matches the
  409. stored hash.
  410. </para>
  411. <para>
  412. Der 'formHidden' View Helfer wird verwendet um das Element in der Form darzustellen.
  413. </para>
  414. </sect2>
  415. <sect2 id="zend.form.standardElements.Image">
  416. <title>Zend_Form_Element_Image</title>
  417. <para>
  418. Bilder können als Form Elemente verwendet werden und man kann diese Bilder als graphische
  419. Elemente auf Form Buttons verwenden.
  420. </para>
  421. <para>
  422. Bilder benötigen eine Bildquelle. <classname>Zend_Form_Element_Image</classname> erlaube dessen
  423. Spezifikation durch Verwendung der <code>setImage()</code> Zugriffsmethode (oder des
  424. 'image' Konfigurations Schlüssels). Es kann auch optional ein Wert spezifiziert werden
  425. der zu verwenden ist wenn das Bild übertragen wird indem die Zugriffsmethode
  426. <code>setImageValue()</code> verwendet wird (oder der 'imageValue Konfigurations
  427. Schlüssel). Wenn der Wert der für das Element gesetzt ist, mit <code>imageValue</code>
  428. übereinstimmt, gibt <code>isChecked()</code> true zurück.
  429. </para>
  430. <para>
  431. Bild Elemente verwenden den
  432. <link linkend="zend.form.standardDecorators.image">Image Decorator</link> für die
  433. Darstellung, zusätzlich zu den Standard Error, HtmlTag und Label Dekoratoren. Es kann
  434. optional ein Tag für den <code>Image</code> Dekorator spezifiziert werden der das
  435. Bild einbettet.
  436. </para>
  437. </sect2>
  438. <sect2 id="zend.form.standardElements.multiCheckbox">
  439. <title>Zend_Form_Element_MultiCheckbox</title>
  440. <para>
  441. Oft hat man ein Set von zusammenhängenden Checkboxen, und die Ergebnisse sollen
  442. gruppiert werden. Das ist so ähnlich wie
  443. <link linkend="zend.form.standardElements.multiselect">Multiselect</link> aber statt
  444. das Sie in einer DropDown Liste sind, müssen Checkbox/Werte Paare dargestellt werden.
  445. </para>
  446. <para>
  447. <classname>Zend_Form_Element_MultiCheckbox</classname> macht das in einem Rutsch. Wie alle
  448. anderen Elemente kann mit der Erweiterung des Basis MultiElements eine Liste von
  449. Optionen spezifiziert werden und einfach gegen die selbe Liste geprüft werden. Der
  450. 'formMultiCheckbox' View Helfer stellt sicher das Sie als Array bei der Übermittlung
  451. der Form zurückgegeben werden.
  452. </para>
  453. <para>
  454. Standardmäßig registriert dieses Element die <code>InArray</code> Prüfung welche gegen
  455. Arrayschlüssel von registrierten Optionen prüft. Dieses Verhalten kann deaktiviert werden
  456. indem entweder <code>setRegisterInArrayValidator(false)</code> aufgerufen, oder indem
  457. ein false Wert an den <code>registerInArrayValidator</code> Konfigurationsschlüssel übergeben
  458. wird.
  459. </para>
  460. <para>
  461. Die verschiedenen Checkbox Optionen können mit den folgenden Methoden manipuliert
  462. werden:
  463. </para>
  464. <itemizedlist>
  465. <listitem><para><code>addMultiOption($option, $value)</code></para></listitem>
  466. <listitem><para><code>addMultiOptions(array $options)</code></para></listitem>
  467. <listitem><para><code>setMultiOptions(array $options)</code> (überschreibt existierende
  468. Optionen)</para></listitem>
  469. <listitem><para><code>getMultiOption($option)</code></para></listitem>
  470. <listitem><para><code>getMultiOptions()</code></para></listitem>
  471. <listitem><para><code>removeMultiOption($option)</code></para></listitem>
  472. <listitem><para><code>clearMultiOptions()</code></para></listitem>
  473. </itemizedlist>
  474. <para>
  475. Um gecheckte Elemente zu markieren, muß ein Array an Werte an <code>setValue()</code> übergeben
  476. werden. Der folgende Code prüft die Werte "bar" und "bat":
  477. </para>
  478. <programlisting role="php"><![CDATA[
  479. $element = new Zend_Form_Element_MultiCheckbox('foo', array(
  480. 'multiOptions' => array(
  481. 'foo' => 'Foo Option',
  482. 'bar' => 'Bar Option',
  483. 'baz' => 'Baz Option',
  484. 'bat' => 'Bat Option',
  485. );
  486. ));
  487. $element->setValue(array('bar', 'bat'));
  488. ]]>
  489. </programlisting>
  490. <para>
  491. Beachte das man auch für das Setzen eines einzelnen Wertes ein Array übergeben muß.
  492. </para>
  493. </sect2>
  494. <sect2 id="zend.form.standardElements.multiselect">
  495. <title>Zend_Form_Element_Multiselect</title>
  496. <para>
  497. XHTML <code>select</code> Elemente erlaube ein 'multiple' Attribut, das zeigt das
  498. mehrere Optionen für die Übermittlung ausgewählt werden können, statt normalerweise
  499. nur eines. <classname>Zend_Form_Element_Multiselect</classname> erweitert
  500. <link linkend="zend.form.standardElements.select">Zend_Form_Element_Select</link> und
  501. setzt das <code>multiple</code> Attribut auf 'multiple'. Wie andere Klassen die von der
  502. Basisklasse <classname>Zend_Form_Element_Multi</classname> abgeleitet werden, können die Optionen
  503. für die Auswahl wie folgt verändert werden:
  504. </para>
  505. <itemizedlist>
  506. <listitem><para><code>addMultiOption($option, $value)</code></para></listitem>
  507. <listitem><para><code>addMultiOptions(array $options)</code></para></listitem>
  508. <listitem><para><code>setMultiOptions(array $options)</code>
  509. (überschreibt existierende Optionen)</para></listitem>
  510. <listitem><para><code>getMultiOption($option)</code></para></listitem>
  511. <listitem><para><code>getMultiOptions()</code></para></listitem>
  512. <listitem><para><code>removeMultiOption($option)</code></para></listitem>
  513. <listitem><para><code>clearMultiOptions()</code></para></listitem>
  514. </itemizedlist>
  515. <para>
  516. Wenn ein Übersetzungs Adapter in der Form und/oder dem Element registriert ist,
  517. werden Optionswerte für Darstellungzwecke übersetzt.
  518. </para>
  519. <para>
  520. Standardmäßig registriert dieses Element die <code>InArray</code> Prüfung welche gegen
  521. Arrayschlüssel von registrierten Optionen prüft. Dieses Verhalten kann deaktiviert werden
  522. indem entweder <code>setRegisterInArrayValidator(false)</code> aufgerufen, oder indem
  523. ein false Wert an den <code>registerInArrayValidator</code> Konfigurationsschlüssel übergeben
  524. wird.
  525. </para>
  526. </sect2>
  527. <sect2 id="zend.form.standardElements.password">
  528. <title>Zend_Form_Element_Password</title>
  529. <para>
  530. Passwort Element sind grundsätzlich normale Textelemente -- ausser das typischerweise
  531. das eingegebene Passwort nicht in Fehlermeldungen oder dem Element selbst angezeigt
  532. werden soll wenn die Form normals angezeigt wird.
  533. </para>
  534. <para>
  535. <classname>Zend_Form_Element_Password</classname> ermöglicht das durch den Aufruf von
  536. <code>setObscureValue(true)</code> auf jeder Prüfung (und stellt sicher das das
  537. Passwort in der Prüfungs Fehlermeldung verschleiert wird), und verwendet den
  538. 'formPassword' View Helfer (welcher den an Ihn übergebenen Wert nicht anzeigt).
  539. </para>
  540. </sect2>
  541. <sect2 id="zend.form.standardElements.radio">
  542. <title>Zend_Form_Element_Radio</title>
  543. <para>
  544. Radio Elemente erlauben es verschiedene Optionen zu spezifizieren, von denen ein
  545. einzelner Wert zurückgegeben wird. <classname>Zend_Form_Element_Radio</classname> erweitert die
  546. Basisklasse <classname>Zend_Form_Element_Multi</classname> und erlaubt es eine Anzahl von
  547. Optionen zu spezifizieren, und verwendet dann den <code>formRadio</code> View Helfer
  548. um diese darzustellen.
  549. </para>
  550. <para>
  551. Standardmäßig registriert dieses Element die <code>InArray</code> Prüfung welche gegen
  552. Arrayschlüssel von registrierten Optionen prüft. Dieses Verhalten kann deaktiviert werden
  553. indem entweder <code>setRegisterInArrayValidator(false)</code> aufgerufen, oder indem
  554. ein false Wert an den <code>registerInArrayValidator</code> Konfigurationsschlüssel übergeben
  555. wird.
  556. </para>
  557. <para>
  558. Wie alle Elemente die die Basisklasse des Mutli Elements erweitern, können die
  559. folgenden Methode verwendet werden um die Radio Optionen zu manipulieren die angezeigt
  560. werden:
  561. </para>
  562. <itemizedlist>
  563. <listitem><para><code>addMultiOption($option, $value)</code></para></listitem>
  564. <listitem><para><code>addMultiOptions(array $options)</code></para></listitem>
  565. <listitem><para><code>setMultiOptions(array $options)</code>
  566. (überschreibt existierende Optionen)</para></listitem>
  567. <listitem><para><code>getMultiOption($option)</code></para></listitem>
  568. <listitem><para><code>getMultiOptions()</code></para></listitem>
  569. <listitem><para><code>removeMultiOption($option)</code></para></listitem>
  570. <listitem><para><code>clearMultiOptions()</code></para></listitem>
  571. </itemizedlist>
  572. </sect2>
  573. <sect2 id="zend.form.standardElements.reset">
  574. <title>Zend_Form_Element_Reset</title>
  575. <para>
  576. Reset Buttons werden typischerweise verwendet um eine Form zu löschen, und sind nicht
  577. Teil der übermittelten Daten. Da Sie trotzdem einen Zweck in der Anzeige bieten, sind
  578. Sie in den Standardelementen enthalten.
  579. </para>
  580. <para>
  581. <classname>Zend_Form_Element_Reset</classname> erweitert
  582. <link linkend="zend.form.standardElements.submit">Zend_Form_Element_Submit</link>.
  583. Deswegen wird das Label für die Anzeige des Buttons verwendet und wird übersetzt
  584. wenn ein Übersetzungs Adapter vorhanden ist. Es verwendet nur die 'ViewHelper' und
  585. 'DtDdWrapper' Dekoratore, da es nie Fehlermeldungen für solche Elemente geben sollte,
  586. noch sollte ein Label notwendig sein.
  587. </para>
  588. </sect2>
  589. <sect2 id="zend.form.standardElements.select">
  590. <title>Zend_Form_Element_Select</title>
  591. <para>
  592. Auswahlboxen sind der übliche Weg um spezielle Auswahlen für gegebene Formdaten zu
  593. begrenzen. <classname>Zend_Form_Element_Select</classname> erlaubt es diese schnell und
  594. einfach zu erzeugen.
  595. </para>
  596. <para>
  597. Standardmäßig registriert dieses Element die <code>InArray</code> Prüfung welche gegen
  598. Arrayschlüssel von registrierten Optionen prüft. Dieses Verhalten kann deaktiviert werden
  599. indem entweder <code>setRegisterInArrayValidator(false)</code> aufgerufen, oder indem
  600. ein false Wert an den <code>registerInArrayValidator</code> Konfigurationsschlüssel übergeben
  601. wird.
  602. </para>
  603. <para>
  604. Da es das Basis Multielement erweitert, können die folgenden Methoden verwendet werden
  605. um die Auswahloptionen zu manipulieren:
  606. </para>
  607. <itemizedlist>
  608. <listitem><para><code>addMultiOption($option, $value)</code></para></listitem>
  609. <listitem><para><code>addMultiOptions(array $options)</code></para></listitem>
  610. <listitem><para><code>setMultiOptions(array $options)</code>
  611. (überschreibt existierende Optionen)</para></listitem>
  612. <listitem><para><code>getMultiOption($option)</code></para></listitem>
  613. <listitem><para><code>getMultiOptions()</code></para></listitem>
  614. <listitem><para><code>removeMultiOption($option)</code></para></listitem>
  615. <listitem><para><code>clearMultiOptions()</code></para></listitem>
  616. </itemizedlist>
  617. <para>
  618. <classname>Zend_Form_Element_Select</classname> verwendet den 'formSelect' View Helfer für
  619. die Dekoration.
  620. </para>
  621. </sect2>
  622. <sect2 id="zend.form.standardElements.submit">
  623. <title>Zend_Form_Element_Submit</title>
  624. <para>
  625. Sendebuttons (Submit) werden verwendet um eine Form zu senden. Es kann gewünscht sein
  626. mehrere Sendebuttons zu verwendetn; die Buttons zur Übermittlung der Form können
  627. verwendet werden um auszuwählen welche Aktion mit den übermittelten Daten genommen
  628. werden soll. <classname>Zend_Form_Element_Submit</classname> macht die Entscheidung einfach,
  629. durch das Hinzufügen einer <code>isChecked()</code> Methode; da nur ein Button Element
  630. von der Form übermittelt wird, nachdem die Form übermittelt oder geprüft wurde, kann
  631. diese Methode auf jedem Sendebutton ausgerufen werden um festzustellen welcher
  632. verwendet wurde.
  633. </para>
  634. <para>
  635. <classname>Zend_Form_Element_Submit</classname> verwendet das Label als den "Wert" des
  636. Sendebuttons, und übersetzt es wenn ein Übersetzungsadapter vorhanden ist.
  637. <code>isChecked()</code> prüft den übermittelten Wert gegen das Label um festzustellen
  638. ob der Button verwendet wurde.
  639. </para>
  640. <para>
  641. Die <link linkend="zend.form.standardDecorators.viewHelper">ViewHelper</link> und
  642. <link linkend="zend.form.standardDecorators.dtDdWrapper">DtDdWrapper</link> Dekoratore
  643. werden verwendet um das Element darzustellen. Es wird kein Labeldekorator verwendet, da
  644. das Label des Buttons verwendet wird wenn das Element dargestellt wird; typischerweise
  645. werden acuh keine Fehler mit einem Sendeelement assoziiert.
  646. </para>
  647. </sect2>
  648. <sect2 id="zend.form.standardElements.text">
  649. <title>Zend_Form_Element_Text</title>
  650. <para>
  651. Der nützlichste Typ von Form Element ist das Text Element, das begrenzte Texteinträge
  652. erlaubt; es ist ein ideales Element für die meisten Dateneinträge.
  653. <classname>Zend_Form_Element_Text</classname> verwendet einfach den 'formText' View Helfer um das
  654. Element darzustellen.
  655. </para>
  656. </sect2>
  657. <sect2 id="zend.form.standardElements.textarea">
  658. <title>Zend_Form_Element_Textarea</title>
  659. <para>
  660. Textbereiche werden verwendet wenn große Mengen von Text erwartet werden, und keine
  661. Begrenzung in der Anzahl des übermittelten Textes vorhanden sind (anders als das Limit
  662. der Maximalgröße wie vom Server von PHP diktiert).
  663. <classname>Zend_Form_Element_Textarea</classname> verwendet den 'textArea' View Helfer um solche
  664. Element darzustellen, und platziert den Wert als Inhalt des Elements.
  665. </para>
  666. </sect2>
  667. </sect1>
  668. <!--
  669. vim:se ts=4 sw=4 tw=80 et:
  670. -->