Zend_Form-StandardElements.xml 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724
  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!-- EN-Revision: 21996 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.form.standardElements">
  5. <title>Les éléments standards fournis avec Zend Framework</title>
  6. <para>
  7. Zend Framework est fournis avec des classes d'éléments couvrant la
  8. plupart des éléments de formulaire HTML. La plupart spécifie un helper de
  9. vue en particulier à utiliser pour décorer un élément, mais plusieurs
  10. d'entre elles offrent des fonctionnalités supplémentaires. Ce qui suit est
  11. une liste de toutes ces classes, ainsi que des descriptions des
  12. fonctionnalités offertes.
  13. </para>
  14. <sect2 id="zend.form.standardElements.button">
  15. <title>Zend_Form_Element_Button</title>
  16. <para>
  17. Utilisé pour créer des éléments boutons,
  18. <classname>Zend_Form_Element_Button</classname> étend <link
  19. linkend="zend.form.standardElements.submit">Zend_Form_Element_Submit</link>,
  20. spécifie quelques fonctionnalités personnalisées. Il spécifie le
  21. helper de vue 'formButton' pour la décoration.
  22. </para>
  23. <para>
  24. Comme l'élément submit, il utilise le label de l'élément en tant que
  25. valeur de l'élément lors de l'affichage ; autrement dit, pour définir
  26. le text du bouton, définissez la valeur de l'élément. Le label sera
  27. traduit si l'adapteur de traduction est présent.
  28. </para>
  29. <para>
  30. Comme le label est utilisé comme faisant partie de l'élément,
  31. l'élément bouton utilise seulement <link
  32. linkend="zend.form.standardDecorators.viewHelper">ViewHelper</link>
  33. et les décorateurs <link
  34. linkend="zend.form.standardDecorators.dtDdWrapper">DtDdWrapper</link>.
  35. </para>
  36. </sect2>
  37. <sect2 id="zend.form.standardElements.captcha">
  38. <title>Zend_Form_Element_Captcha</title>
  39. <para>
  40. Les CAPTCHAs sont utilisé pour empêcher la soumission automatique des
  41. formulaires par des bots et autre processus automatisés.
  42. </para>
  43. <para>
  44. L'élément de formulaire Captcha permet de spécifier quel <link
  45. linkend="zend.captcha.adapters">Adapteur Zend_Captcha</link> vous
  46. désirez utiliser. Il définit ensuite cet adapteur comme
  47. validateur à l'objet, et utilise le décorateur du Captcha pour
  48. l'affichage (ce qui fait office de proxy vers l'adapteur CAPTCHA).
  49. </para>
  50. <para>
  51. Les adapteurs peuvent être n'importe quel adapteur de
  52. <classname>Zend_Captcha</classname>, ou n'importe quel adapteur que
  53. vous avez défini par ailleurs. Pour permettre ceci, vous devrez passer
  54. une clé supplémentaire de plugin loader, 'CAPTCHA'
  55. ou 'captcha', lorsque vous spécifiez un prefixe de chemin de plugin loader :
  56. </para>
  57. <programlisting language="php"><![CDATA[
  58. $element->addPrefixPath('My_Captcha', 'My/Captcha/', 'captcha');
  59. ]]></programlisting>
  60. <para>
  61. Le Captcha peut ensuite être enregistré en utilisant la méthode
  62. <methodname>setCaptcha()</methodname>, qui prend en paramètre soit
  63. une instance concrête de CAPTCHA soit le nom court d'un adapteur CAPTCHA :
  64. </para>
  65. <programlisting language="php"><![CDATA[
  66. // Instance concrête:
  67. $element->setCaptcha(new Zend_Captcha_Figlet());
  68. // Utilisation d'un nom court :
  69. $element->setCaptcha('Dumb');
  70. ]]></programlisting>
  71. <para>
  72. Si vous souhaitez charger votre élément via la configuration, spécifiez soit
  73. la clé 'captcha' avec un tableau contenant la clé 'captcha', soit les clés
  74. 'captcha' et 'captchaOptions' :
  75. </para>
  76. <programlisting language="php"><![CDATA[
  77. // Utilisation d'une clé captcha :
  78. $element = new Zend_Form_Element_Captcha('foo', array(
  79. 'label' => "Merci de confirmer que vous êtes humain",
  80. 'captcha' => array(
  81. 'captcha' => 'Figlet',
  82. 'wordLen' => 6,
  83. 'timeout' => 300,
  84. ),
  85. ));
  86. // Utilisation simultanée des clés captcha et captchaOption :
  87. $element = new Zend_Form_Element_Captcha('foo', array(
  88. 'label' => "Merci de confirmer que vous êtes humain",
  89. 'captcha' => 'Figlet',
  90. 'captchaOptions' => array(
  91. 'captcha' => 'Figlet',
  92. 'wordLen' => 6,
  93. 'timeout' => 300,
  94. ),
  95. ));
  96. ]]></programlisting>
  97. <para>
  98. Le décorateur utilisé est déterminé lors de la récupération de l'adapteur
  99. du captcha. Par défaut, le <link
  100. linkend="zend.form.standardDecorators.captcha"> décorateur
  101. du captcha</link> est utilisé, mais un adapteur peut spécifier un décorateur
  102. différent via sa méthode <methodname>getDecorator()</methodname>.
  103. </para>
  104. <para>
  105. Comme noté, l'adapteur de captcha lui même agit comme un validateur pour
  106. l'élément. De plus, le validateur NotEmpty n'est pas utilisé, et l'élément
  107. est marqué comme requis. Dans la plupart des cas, vous n'aurez besoin de
  108. rien d'autre pour que le captcha soit présent dans votre formulaire.
  109. </para>
  110. </sect2>
  111. <sect2 id="zend.form.standardElements.checkbox">
  112. <title>Zend_Form_Element_Checkbox</title>
  113. <para>
  114. Les cases à cocher HTML vous permettent de retourner une valeur spécifique,
  115. mais elles fonctionnent essentiellement comme des booléens. Lorsque elle
  116. est cochée, la valeur de la case à cocher est soumise. Lorsque la case à
  117. cocher n'est pas cochée, rien n'est soumis. En interne,
  118. <classname>Zend_Form_Element_Checkbox</classname> applique cet état.
  119. </para>
  120. <para>
  121. Par défaut, la valeur cochée est '1', et la valeur non cochée est '0'.
  122. Vous pouvez spécifier les valeurs en utilisant respectivement les accesseurs
  123. <methodname>setCheckedValue()</methodname>
  124. et <methodname>setUncheckedValue()</methodname>. En interne, à chaque fois que
  125. vous définissez une valeur, si la valeur fournie correspond à la valeur cochée,
  126. alors elle sera définie, mais toutes autres valeurs aura pour effet que la valeur
  127. non cochée sera sélectionnée.
  128. </para>
  129. <para>
  130. En sus, définir la valeur définit la propriété <code>checked</code>
  131. de la case à cocher. Vous pouvez la récupérer en utilisant
  132. <methodname>isChecked()</methodname> ou simplement en accédant à la propriété.
  133. Utiliser la méthode <methodname>setChecked($flag)</methodname> l'état du flag
  134. ainsi que la valeur cochée ou non cochée de l'élément.
  135. Veillez à utiliser cette méthode lorsque vous définissez l'état coché d'un élément
  136. case à cocher afin d'être sûr que la valeur est correctement définie.
  137. </para>
  138. <para>
  139. <classname>Zend_Form_Element_Checkbox</classname> utilise le helper de vue
  140. 'formCheckbox'. La valeur cochée est toujours utilisé pour le remplir.
  141. </para>
  142. </sect2>
  143. <sect2 id="zend.form.standardElements.file">
  144. <title>Zend_Form_Element_File</title>
  145. <para>
  146. L'élément de formulaire File fournit un mécanisme pour fournir des champs
  147. d'upload de fichier à votre formulaire. Il utilise <link
  148. linkend="zend.file.transfer.introduction">Zend_File_Transfer</link>
  149. en interne pour fournir cette fonctionnalité et le helper de vue
  150. <code>FormFile</code> ainsi que le décorateur <code>File</code>
  151. pour afficher l'élément de formulaire.
  152. </para>
  153. <para>
  154. Par défaut, il utilise l'adapteur de transfert<code>Http</code> qui
  155. inspecte le tableau <varname>$_FILES</varname> et vous permet d'attacher
  156. des validateurs et des filtres. Les validateurs et les filtres attachés
  157. au formulaire sont à leur tour attachés à l'adapteur de transfert.
  158. </para>
  159. <example id="zend.form.standardElements.file.usage">
  160. <title>Utilisation de l'élément de formulaire File</title>
  161. <para>
  162. L'explication d'utilisation de l'élément de formulaire File ci-dessous
  163. peut sembler ésotérique, mais l'usage est en fait relativement trivial :
  164. </para>
  165. <programlisting language="php"><![CDATA[
  166. $element = new Zend_Form_Element_File('foo');
  167. $element->setLabel('Upload une image:')
  168. ->setDestination('/var/www/upload');
  169. // Fait en sorte qu'il y ait un seul fichier
  170. $element->addValidator('Count', false, 1);
  171. // limite à 100K
  172. $element->addValidator('Size', false, 102400);
  173. // seulement des JPEG, PNG, et GIFs
  174. $element->addValidator('Extension', false, 'jpg,png,gif');
  175. $form->addElement($element, 'foo');
  176. ]]></programlisting>
  177. <para>
  178. Vous devez aussi vous assurer que le type d'encodage correct est fourni au
  179. formulaire ; vous devez utiliser 'multipart/form-data'. Vous pouvez faire
  180. cela en définissant l'attribut 'enctype' du formulaire:
  181. </para>
  182. <programlisting language="php"><![CDATA[
  183. $form->setAttrib('enctype', 'multipart/form-data');
  184. ]]></programlisting>
  185. <para>
  186. Après que le formulaire soit validé avec succès, vous devriez recevoir
  187. le fichier afin de le stocker dans sa destination finale en utilisant
  188. <methodname>receive()</methodname>.
  189. De plus, vous pouvez déterminer son emplacement finale en utilisant
  190. <methodname>getFileName()</methodname>:
  191. </para>
  192. <programlisting language="php"><![CDATA[
  193. if (!$form->isValid()) {
  194. print "Uh oh... erreur de validation";
  195. }
  196. if (!$form->foo->receive()) {
  197. print "Erreur de réception de fichier";
  198. }
  199. $location = $form->foo->getFileName();
  200. ]]></programlisting>
  201. </example>
  202. <note>
  203. <title>Emplacement d'upload par défaut</title>
  204. <para>
  205. Par défaut, les fichiers sont uploadés dans le répertoire temp
  206. du système.
  207. </para>
  208. </note>
  209. <note>
  210. <title>Valeur de fichier</title>
  211. <para>
  212. Au sein du <acronym>HTTP</acronym> un élément fichier n'a aucune valeur.
  213. Pour cette raison et pour des raisons de sécurité
  214. <methodname>getValue()</methodname> retourne seulement le nom du fichier
  215. uploadé et non le chemin complet. Si vous avez besoin du chemin du fichier,
  216. appellez <methodname>getFileName()</methodname>, qui retourne à la fois le
  217. chemin et le nom du fichier.
  218. </para>
  219. </note>
  220. <para>
  221. Par défaut, le fichier sera automatiquement reçu quand vous appellerez
  222. <methodname>getValues()</methodname> sur le formulaire. La raison derrière
  223. ce comportement est que le fichier lui même est la valeur de l'élément fichier.
  224. </para>
  225. <programlisting language="php"><![CDATA[
  226. $form->getValues();
  227. ]]></programlisting>
  228. <note>
  229. <para>
  230. Ainsi, un appel supplémentaire de <methodname>receive()</methodname> après avoir
  231. appellé <methodname>getValues()</methodname> n'aura aucun effet. De même, créer
  232. une instance de <classname>Zend_File_Transfer</classname> n'aura aucun effet non
  233. plus puisqu'il n'y aura plus de fichier à recevoir.
  234. </para>
  235. </note>
  236. <para>
  237. Cela dit, parfois vous aurez besoin d'appeller <methodname>getValues()</methodname> sans
  238. recevoir le fichier. Vous pouvez l'archiver en appellant
  239. <methodname>setValueDisabled(true)</methodname>. Afin de recevoir la véritable valeur de
  240. ce flag vous pouvez appeller <methodname>isValueDisabled()</methodname>.
  241. </para>
  242. <example id="zend.form.standardElements.file.retrievement">
  243. <title>Récupération explicite de fichier</title>
  244. <para>
  245. Tout d'abord appellez<methodname>setValueDisabled(true)</methodname>.
  246. </para>
  247. <programlisting language="php"><![CDATA[
  248. $element = new Zend_Form_Element_File('foo');
  249. $element->setLabel('Uploadez une image:')
  250. ->setDestination('/var/www/upload')
  251. ->setValueDisabled(true);
  252. ]]></programlisting>
  253. <para>
  254. Désormais le fichier sera reçu lorsque vous appellerez
  255. <methodname>getValues()</methodname>. Donc vous devez appeller vous même
  256. <methodname>receive()</methodname> sur l'élément fichier, ou une instance de
  257. <classname>Zend_File_Transfer</classname> .
  258. </para>
  259. <programlisting language="php"><![CDATA[
  260. $values = $form->getValues();
  261. if ($form->isValid($form->getPost())) {
  262. if (!$form->foo->receive()) {
  263. print "Erreur d'upload";
  264. }
  265. }
  266. ]]></programlisting>
  267. </example>
  268. <para>
  269. Il ya plusieurs étapes du fichier uploadés qui peuvent être vérifiées
  270. avec les méthodes suivantes :
  271. </para>
  272. <itemizedlist>
  273. <listitem>
  274. <para>
  275. <methodname>isUploaded()</methodname> : Vérifie si l'élément fichier
  276. a été uploadé ou non.
  277. </para>
  278. </listitem>
  279. <listitem>
  280. <para>
  281. <methodname>isReceived()</methodname> : Vérifie si l'élément fichier
  282. a déjà été reçu.
  283. </para>
  284. </listitem>
  285. <listitem>
  286. <para>
  287. <methodname>isFiltered()</methodname> : Vérifie si les filtres ont
  288. déjà été appliqué ou non sur l'élément fichier.
  289. </para>
  290. </listitem>
  291. </itemizedlist>
  292. <example id="zend.form.standardElements.file.isuploaded">
  293. <title>Vérifier si un fichier optionnel a été uploadé</title>
  294. <programlisting language="php"><![CDATA[
  295. $element = new Zend_Form_Element_File('foo');
  296. $element->setLabel('Uploader une image:')
  297. ->setDestination('/var/www/upload')
  298. ->setRequired(false);
  299. $element->addValidator('Size', false, 102400);
  300. $form->addElement($element, 'foo');
  301. // L'élément fichier foo est optionnel mais quand il est renseigné va là
  302. if ($form->foo->isUploaded()) {
  303. // fichier foo donné, faire quelque chose
  304. }
  305. ]]></programlisting>
  306. </example>
  307. <para>
  308. <classname>Zend_Form_Element_File</classname> supporte aussi les fichiers multiples.
  309. En appellant la méthode <methodname>setMultiFile($count)</methodname> vous pouvez définir,
  310. le nombre d'éléments fichier à créer. Ceci vous évite de définir les mêmes
  311. réglages plusieurs fois.
  312. </para>
  313. <example id="zend.form.standardElements.file.multiusage">
  314. <title>Définir plusieurs fichiers</title>
  315. <para>
  316. Créer un élément multifichier est identique à la création d'un élément unique.
  317. Appellez simplement <methodname>setMultiFile()</methodname> après que l'élément soit créé:
  318. </para>
  319. <programlisting language="php"><![CDATA[
  320. $element = new Zend_Form_Element_File('foo');
  321. $element->setLabel('Uploadez une image:')
  322. ->setDestination('/var/www/upload');
  323. // s'assure qu'il y a un fichier au minimum, 3 au maximum
  324. $element->addValidator('Count', false, array('min' => 1, 'max' => 3));
  325. // Limite à 100K
  326. $element->addValidator('Size', false, 102400);
  327. // seulement des JPEG, PNG, et des GIF
  328. $element->addValidator('Extension', false, 'jpg,png,gif');
  329. // définit 3 éléments fichiers identiques
  330. $element->setMultiFile(3);
  331. $form->addElement($element, 'foo');
  332. ]]></programlisting>
  333. <para>
  334. Vous avez maintenant 3 éléments d'upload de fichier identiques
  335. avec les mêmes paramètres. Pour obtenir le nombre de fichiers multiples
  336. défini, appellez simplement
  337. <methodname>getMultiFile()</methodname>.
  338. </para>
  339. </example>
  340. <note>
  341. <title>Eléments de fichier dans un sous formulaire</title>
  342. <para>
  343. Quand vous l'utilisez dans des sous formulaires, vous devez définir
  344. des noms uniques.
  345. Par exemple, si vous nommez un élément fichier "file" dans le subform1,
  346. vous devez un nom différent à tout autre élément fichier dans subform2.
  347. </para>
  348. <para>
  349. Si il y a deux éléments fichier portant le même nom, le second élément
  350. n'est pas affiché ou soumis.
  351. </para>
  352. <para>
  353. De plus, les éléments fichiers ne sont pas affichés au sein du sous formulaire.
  354. Donc lorsque vous ajouter un élément fichier dans un sous formulaire, l'élément
  355. sera affiché dans le formulaire principal.
  356. </para>
  357. </note>
  358. <para>
  359. Afin de limiter, vous pouvez spécifier la taille maximum d'un fichier en définissant
  360. l'option <constant>MAX_FILE_SIZE</constant> sur le formulaire. Quand vous définissez
  361. cette valeur en utilisant la méthode
  362. <methodname>setMaxFileSize($size)</methodname>, elle sera affiché avec l'élément
  363. fichier.
  364. </para>
  365. <programlisting language="php"><![CDATA[
  366. $element = new Zend_Form_Element_File('foo');
  367. $element->setLabel('Uploadez une image:')
  368. ->setDestination('/var/www/upload')
  369. ->addValidator('Size', false, 102400) // limit to 100K
  370. ->setMaxFileSize(102400); // limite la taille de fichier coté client
  371. $form->addElement($element, 'foo');
  372. ]]></programlisting>
  373. <note>
  374. <title>MaxFileSize et Eléments fichier multiple</title>
  375. <para>
  376. Quand vous utilisez des éléments fichiers multiples dans votre formulaire
  377. vous devez définir <constant>MAX_FILE_SIZE</constant> seulement une fois.
  378. La redéfinir écrasera la valeur précédente.
  379. </para>
  380. <para>
  381. Notez que c'est aussi le cas lorsque vous utilisez des formulaires multiples.
  382. </para>
  383. </note>
  384. </sect2>
  385. <sect2 id="zend.form.standardElements.hidden">
  386. <title>Zend_Form_Element_Hidden</title>
  387. <para>
  388. Les éléments cachés injectent des données qui doivent être soumises, mais pas manipulées
  389. par l'utilisateur. <classname>Zend_Form_Element_Hidden</classname> remplit cette tâche
  390. avec le helper de vue 'formHidden'.
  391. </para>
  392. </sect2>
  393. <sect2 id="zend.form.standardElements.hash">
  394. <title>Zend_Form_Element_Hash</title>
  395. <para>
  396. Cette élément fournit une proctection contre les attaques CSRF sur les formulaires,
  397. en s'assurant que les données sont soumises par la session utilisateur qui a
  398. générée le formulaire et non par un script malveillant. La protection est réalisée
  399. en ajouté un élément de hachage au formulaire et en le vérifiant lors de la soumission
  400. du formulaire.
  401. </para>
  402. <para>
  403. Le nom de l'élément de hachage doit être unique. Nous recommandons d'utiliser
  404. l'option <literal>salt</literal> pour l'élément - deux hachages ayant le même nom
  405. mais des salt différent ne causeront pas de collision :
  406. </para>
  407. <programlisting language="php"><![CDATA[
  408. $form->addElement('hash', 'no_csrf_foo', array('salt' => 'unique'));
  409. ]]></programlisting>
  410. <para>
  411. Vous pouvez définir le salt ultérieurement en utilisant la méthode
  412. <methodname>setSalt($salt)</methodname>.
  413. </para>
  414. <para>
  415. En interne, l'élément stocke un identifiant unique en utilisant
  416. <classname>Zend_Session_Namespace</classname>, et le vérifie lors de la soumission
  417. (en vérifiant que le TTL n'a pas expiré). Le validateur 'Identical' est ensuite
  418. utilisé pour s'assurer que le hachage soumis correspond au hachage stocké.
  419. </para>
  420. <para>
  421. Le helper de vue 'formHidden' est utilisé pour rendre l'élément dans le formulaire.
  422. </para>
  423. </sect2>
  424. <sect2 id="zend.form.standardElements.Image">
  425. <title>Zend_Form_Element_Image</title>
  426. <para>
  427. Des images peuvent être utilisées comme éléments de formulaires, et vous
  428. pouvez utiliser ces images en tant qu'éléments graphiques sur les
  429. boutons de formulaires.
  430. </para>
  431. <para>
  432. Les images ont besoin d'une image source. <classname>Zend_Form_Element_Image</classname>
  433. permet de la spécifier en utilisant l'accesseur <methodname>setImage()</methodname>
  434. (ou la clé de configuration 'imageValue'). Quant la valeur définie pour l'élément
  435. corresponde à <code>imageValue</code>, alors l'accesseur
  436. <methodname>isChecked()</methodname> retournera <constant>TRUE</constant>.
  437. </para>
  438. <para>
  439. Les éléments image utilise le
  440. <link linkend="zend.form.standardDecorators.image"> décorateur Image
  441. </link> pour le rendu, en plus des décorateur standard Errors,
  442. HtmlTag et Label. Vous pouvez spécifier une balise en option au décorateur
  443. <code>Image</code> qui entourera l'élément image.
  444. </para>
  445. </sect2>
  446. <sect2 id="zend.form.standardElements.multiCheckbox">
  447. <title>Zend_Form_Element_MultiCheckbox</title>
  448. <para>
  449. Souvent, vous pouvez avoir un ensemble de case à cocher apparenté, et vous
  450. souhaitez grouper ces résultat. Cela ressemble beaucoup à <link
  451. linkend="zend.form.standardElements.multiselect"> Multiselect</link>,
  452. mais au lieu que ce soit une liste déroulant, vous avez besoin d'afficher
  453. des paires case à cocher/valeur.
  454. </para>
  455. <para>
  456. <classname>Zend_Form_Element_MultiCheckbox</classname> rend cela simple
  457. comme bonjour. Comme tous les éléments qui étendent l'élément de base Multi,
  458. vous pouvez spécifier une liste d'options et les valider simplement à l'aide
  459. de cette même liste. Le helper de vue 'formMultiCheckbox' s'assure qu'elles
  460. seront retournées dans un tableau lors la soumission du formulaire.
  461. </para>
  462. <para>
  463. Par défaut, cet élément enregistre un validateur <code>InArray</code>
  464. qui effectue la validation à l'aide des clés du tableau d'options enregistrées.
  465. Vous pouvez désactiver ce comportement, soit en appellant
  466. <methodname>setRegisterInArrayValidator(false)</methodname>, soit en passant
  467. une valeur <constant>FALSE</constant> à la clé de configuration
  468. <code>registerInArrayValidator</code>.
  469. </para>
  470. <para>
  471. Vous pouvez manipuler les diverses options de case à cocher en utilisant
  472. les méthodes suivantes :
  473. </para>
  474. <itemizedlist>
  475. <listitem>
  476. <para><methodname>addMultiOption($option, $value)</methodname></para>
  477. </listitem>
  478. <listitem>
  479. <para><methodname>addMultiOptions(array $options)</methodname></para>
  480. </listitem>
  481. <listitem>
  482. <para>
  483. <methodname>setMultiOptions(array $options)</methodname> (écrase les options
  484. existantes)
  485. </para>
  486. </listitem>
  487. <listitem><para><methodname>getMultiOption($option)</methodname></para></listitem>
  488. <listitem><para><methodname>getMultiOptions()</methodname></para></listitem>
  489. <listitem><para><methodname>removeMultiOption($option)</methodname></para></listitem>
  490. <listitem><para><methodname>clearMultiOptions()</methodname></para></listitem>
  491. </itemizedlist>
  492. <para>
  493. Pour marquer les éléments cochés, vous devez passer un tableau de valeur à
  494. <methodname>setValue()</methodname>. Ce qui suit cochera les valeur "bar"
  495. et "bat":
  496. </para>
  497. <programlisting language="php"><![CDATA[
  498. $element = new Zend_Form_Element_MultiCheckbox('foo', array(
  499. 'multiOptions' => array(
  500. 'foo' => 'Foo Option',
  501. 'bar' => 'Bar Option',
  502. 'baz' => 'Baz Option',
  503. 'bat' => 'Bat Option',
  504. )
  505. ));
  506. $element->setValue(array('bar', 'bat'));
  507. ]]></programlisting>
  508. <para>
  509. Notez que même en définissant une valeur unique vous devrez passer un tableau.
  510. </para>
  511. </sect2>
  512. <sect2 id="zend.form.standardElements.multiselect">
  513. <title>Zend_Form_Element_Multiselect</title>
  514. <para>
  515. Les éléments <code>select</code> <acronym>XHTML</acronym> autorisent un attribut
  516. 'multiple', indiquant que plusieurs options peuvent être sélectionné pour la soumission
  517. du formulaire, au lieu d'une seule habituellement.
  518. <classname>Zend_Form_Element_Multiselect</classname> étend
  519. <link
  520. linkend="zend.form.standardElements.select">Zend_Form_Element_Select</link>,
  521. et définit l'attribut <code>multiple</code> à 'multiple'. Comme les autres classes qui
  522. hétite la classe de base
  523. <classname>Zend_Form_Element_Multi</classname>, vous pouvez manipuler les options
  524. du select en utilisant :
  525. </para>
  526. <itemizedlist>
  527. <listitem>
  528. <para><methodname>addMultiOption($option, $value)</methodname></para>
  529. </listitem>
  530. <listitem>
  531. <para><methodname>addMultiOptions(array $options)</methodname></para>
  532. </listitem>
  533. <listitem>
  534. <para>
  535. <methodname>setMultiOptions(array $options)</methodname> (écrase les options
  536. existantes)
  537. </para>
  538. </listitem>
  539. <listitem><para><methodname>getMultiOption($option)</methodname></para></listitem>
  540. <listitem><para><methodname>getMultiOptions()</methodname></para></listitem>
  541. <listitem><para><methodname>removeMultiOption($option)</methodname></para></listitem>
  542. <listitem><para><methodname>clearMultiOptions()</methodname></para></listitem>
  543. </itemizedlist>
  544. <para>
  545. Si un adapteur de traduction est enregistré au niveau du formulaire et/ou
  546. de l'élément, les valeurs des options seront traduites dans le cadre de
  547. l'affichage.
  548. </para>
  549. <para>
  550. Par défaut, cette élément utilise un validateur <code>InArray</code>
  551. qui effectue sa validation à partir des clés de tableau des options enregistrées.
  552. Vous pouvez désactiver ce comportement, soit en appellant
  553. <methodname>setRegisterInArrayValidator(false)</methodname>, ou en passant une valeur
  554. <constant>FALSE</constant> à la clé de configuration
  555. <code>registerInArrayValidator</code>.
  556. </para>
  557. </sect2>
  558. <sect2 id="zend.form.standardElements.password">
  559. <title>Zend_Form_Element_Password</title>
  560. <para>
  561. Les éléments mot de passe sont fondamentalement des éléments texte normaux
  562. -- à l'exception du fait que vous ne voulez pas que le mot de passe soumis
  563. soit affiché dans les messages d'erreurs ou lorsque le formulaire est
  564. affiché à nouveau.
  565. </para>
  566. <para>
  567. <classname>Zend_Form_Element_Password</classname> effectue cela en appellant
  568. <methodname>setObscureValue(true)</methodname> sur chaque validateur (s'assurant
  569. ainsi que le mot de passe est dissimulé dans les messages d'erreur de validation),
  570. et utilise le helper de vue 'formPassword' qui n'affiche pas la valeur qui lui est
  571. passé).
  572. </para>
  573. </sect2>
  574. <sect2 id="zend.form.standardElements.radio">
  575. <title>Zend_Form_Element_Radio</title>
  576. <para>
  577. Les éléments radio vous permettend de spécifier plusieurs options, parmi
  578. lesquelles vous n'avez besoin que d'une seule. <classname>Zend_Form_Element_Radio</classname>
  579. étend la classe de base <classname>Zend_Form_Element_Multi</classname>,
  580. vous permettant ainsi de spécifier un nombre indéfini d'options, et utilise
  581. ensuite le helper de vue <code>formRadio</code> pour les afficher.
  582. </para>
  583. <para>
  584. Par défaut, cette élément utilise un validateur <code>InArray</code>
  585. qui effectue sa validation à partir des clés de tableau des options enregistrées.
  586. Vous pouvez désactiver ce comportement, soit en appellant
  587. <methodname>setRegisterInArrayValidator(false)</methodname>, ou en passant une valeur
  588. <constant>FALSE</constant> à la clé de configuration
  589. <code>registerInArrayValidator</code>.
  590. </para>
  591. <para>
  592. Comme tous les éléments étendant la classe de base Multi element, les méthodes
  593. suivantes peuvent être utilisé pour manipuler les options radio affichées :
  594. </para>
  595. <itemizedlist>
  596. <listitem>
  597. <para><methodname>addMultiOption($option, $value)</methodname></para>
  598. </listitem>
  599. <listitem>
  600. <para><methodname>addMultiOptions(array $options)</methodname></para>
  601. </listitem>
  602. <listitem>
  603. <para>
  604. <methodname>setMultiOptions(array $options)</methodname>
  605. (écrase les options existantes)
  606. </para>
  607. </listitem>
  608. <listitem><para><methodname>getMultiOption($option)</methodname></para></listitem>
  609. <listitem><para><methodname>getMultiOptions()</methodname></para></listitem>
  610. <listitem><para><methodname>removeMultiOption($option)</methodname></para></listitem>
  611. <listitem><para><methodname>clearMultiOptions()</methodname></para></listitem>
  612. </itemizedlist>
  613. </sect2>
  614. <sect2 id="zend.form.standardElements.reset">
  615. <title>Zend_Form_Element_Reset</title>
  616. <para>
  617. Les boutons de mise à zéro sont typiquement utilisé pour vider un formulaire,
  618. et ne font pas partie des données soumises. Cela dit, comme ils remplissent un rôle
  619. dans l'affichage, ils sont inclus dans les éléments standards.
  620. </para>
  621. <para>
  622. <classname>Zend_Form_Element_Reset</classname> étend <link
  623. linkend="zend.form.standardElements.submit">Zend_Form_Element_Submit</link>.
  624. Ainsi, le label est utilisé pour l'affichage du bouton et sera traduit, si un
  625. adapteur de traduction est présent. Il utilise seulement les décorateurs
  626. 'ViewHelper' et 'DtDdWrapper', puisqu'il ne devrait jamais y avoir de messages
  627. d'erreur pour ces éléments, le label ne sera pas non plus nécessaire.
  628. </para>
  629. </sect2>
  630. <sect2 id="zend.form.standardElements.select">
  631. <title>Zend_Form_Element_Select</title>
  632. <para>
  633. Les listes d'options sont une manière habituelle de limiter des choix spécifiques.
  634. <classname>Zend_Form_Element_Select</classname> vous permet de les générer
  635. rapidement et facilement.
  636. </para>
  637. <para>
  638. Par défaut, cette élément utilise un validateur <code>InArray</code>
  639. qui effectue sa validation à partir des clés de tableau des options enregistrées.
  640. Vous pouvez désactiver ce comportement, soit en appellant
  641. <methodname>setRegisterInArrayValidator(false)</methodname>, ou en passant une valeur
  642. <constant>FALSE</constant> à la clé de configuration
  643. <code>registerInArrayValidator</code>.
  644. </para>
  645. <para>
  646. Comme il étend l'élément de base Multi, les méthodes suivantes peuvent
  647. être utilisées pour manipuler les options du select :
  648. </para>
  649. <itemizedlist>
  650. <listitem>
  651. <para><methodname>addMultiOption($option, $value)</methodname></para>
  652. </listitem>
  653. <listitem>
  654. <para><methodname>addMultiOptions(array $options)</methodname></para>
  655. </listitem>
  656. <listitem>
  657. <para>
  658. <methodname>setMultiOptions(array $options)</methodname>
  659. (écrase les options existantes)
  660. </para>
  661. </listitem>
  662. <listitem><para><methodname>getMultiOption($option)</methodname></para></listitem>
  663. <listitem><para><methodname>getMultiOptions()</methodname></para></listitem>
  664. <listitem><para><methodname>removeMultiOption($option)</methodname></para></listitem>
  665. <listitem><para><methodname>clearMultiOptions()</methodname></para></listitem>
  666. </itemizedlist>
  667. <para>
  668. <classname>Zend_Form_Element_Select</classname> utilise le helper de vue
  669. 'formSelect pour la décoration.
  670. </para>
  671. </sect2>
  672. <sect2 id="zend.form.standardElements.submit">
  673. <title>Zend_Form_Element_Submit</title>
  674. <para>
  675. Les boutons Submit sont utilisé pour soumettre un formulaire. Vous pouvez
  676. utiliser plusieurs boutons submit ; vous pouvez utiliser le bouton utilisé
  677. pour soumettre le formulaire afin de décider quelle action effectuer avec
  678. les données soumises.
  679. <classname>Zend_Form_Element_Submit</classname> rend cette décisions simple,
  680. en ajoutant une méthode <methodname>isChecked()</methodname> method ; puisqu'un
  681. seul élément bouton sera soumis par le formulaire, après avoir rempli ou validé
  682. le formulaire, vous pourrez appeller cette méthode sur chacun des boutons submit
  683. afin de déterminer lequel a été utilisé.
  684. </para>
  685. <para>
  686. <classname>Zend_Form_Element_Submit</classname> utilise le label comme "value"
  687. du bouton submit, il sera traduit si un adapeur de traduction est présent.
  688. <methodname>isChecked()</methodname> vérifie la valeur soumises avec
  689. le label pour déterminer si le bouton a été utilisé.
  690. </para>
  691. <para>
  692. Les décorateurs <link
  693. linkend="zend.form.standardDecorators.viewHelper">ViewHelper</link>
  694. et <link
  695. linkend="zend.form.standardDecorators.dtDdWrapper">DtDdWrapper</link>
  696. sont utilisé pour rendre cet élément. Aucun décorateur de label n'est utilisé,
  697. puisque le label du bouton est utilisé lors du rendu de l'élément ; de plus,
  698. vous n'associerez aucune erreurs avec l'élément submit.
  699. </para>
  700. </sect2>
  701. <sect2 id="zend.form.standardElements.text">
  702. <title>Zend_Form_Element_Text</title>
  703. <para>
  704. De loin le type d'élément de formulaire le plus répandu est l'élément text,
  705. celui ci autorise des saisies de texte limité ; c'est un élément idéal pour
  706. la plupart des saisies de données. <classname>Zend_Form_Element_Text</classname>
  707. utilise simplement le helper de vue 'formText' pour afficher l'élément.
  708. </para>
  709. </sect2>
  710. <sect2 id="zend.form.standardElements.textarea">
  711. <title>Zend_Form_Element_Textarea</title>
  712. <para>
  713. Les Textareas sont utilisé lorsque de grandes quantités de texte sont
  714. attendues, et ne limite pas la quantité de texte soumise (si ce n'est la
  715. taille limite fixée par votre serveur ou <acronym>PHP</acronym>).
  716. <classname>Zend_Form_Element_Textarea</classname> utilise le helper de vue
  717. 'textArea' pour afficher ces éléments, et place la valeur comme contenu de
  718. l'élément.
  719. </para>
  720. </sect2>
  721. </sect1>
  722. <!--
  723. vim:se ts=4 sw=4 tw=80 et:
  724. -->