Zend_Form-QuickStart.xml 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 24249 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.form.quickstart">
  5. <title>Zend_Form démarrage rapide</title>
  6. <para>
  7. Ce guide rapide couvre les bases de la création, de la validation, et du rendu des
  8. formulaires <classname>Zend_Form</classname>.
  9. </para>
  10. <sect2 id="zend.form.quickstart.create">
  11. <title>Créer un objet de formulaire</title>
  12. <para>Instanciez simplement un objet <classname>Zend_Form</classname>&#160;:</para>
  13. <programlisting language="php"><![CDATA[
  14. $form = new Zend_Form;
  15. ]]></programlisting>
  16. <para>
  17. Pour des usages avancés, vous voudriez probablement dériver
  18. <classname>Zend_Form</classname>, mais pour les formulaires simples, vous pouvez créez
  19. un formulaire depuis une instance de <classname>Zend_Form</classname>.
  20. </para>
  21. <para>
  22. Vous pouvez spécifier (c'est une bonne idée) l'action et la méthode d'envoi du
  23. formulaire grâce à <methodname>setAction()</methodname> et <methodname>setMethod()</methodname>&#160;:
  24. </para>
  25. <programlisting language="php"><![CDATA[
  26. $form->setAction('/resource/process')
  27. ->setMethod('post');
  28. ]]></programlisting>
  29. <para>
  30. Le code ci-dessus indique au formulaire d'être envoyé vers l'URL
  31. "/resource/process" avec la méthode <acronym>HTTP</acronym> POST. Ceci va impacter le rendu du formulaire
  32. (la balise <code>&lt;form&gt;</code>).
  33. </para>
  34. <para>
  35. Il est possible d'assigner les attributs HTML supplémentaires à la balise
  36. <code>&lt;form&gt;</code> via la méthode <methodname>setAttrib()</methodname> ou encore
  37. <methodname>setAttribs()</methodname>. Par exemple, indiquons un attribut "id" au formulaire&#160;:
  38. </para>
  39. <programlisting language="php"><![CDATA[
  40. $form->setAttrib('id', 'login');
  41. ]]></programlisting>
  42. </sect2>
  43. <sect2 id="zend.form.quickstart.elements">
  44. <title>Ajouter des éléments au formulaire</title>
  45. <para>
  46. Un formulaire ne sert à rien sans éléments. Le composant
  47. <classname>Zend_Form</classname> est fourni avec un ensemble d'éléments qui rendent du
  48. code <acronym>XHTML</acronym> via les aides de <classname>Zend_View</classname>. Voici ces aides&#160;:
  49. </para>
  50. <itemizedlist>
  51. <listitem>
  52. <para>button</para>
  53. </listitem>
  54. <listitem>
  55. <para>checkbox (ou plusieurs checkboxes avec multiCheckbox)</para>
  56. </listitem>
  57. <listitem>
  58. <para>hidden</para>
  59. </listitem>
  60. <listitem>
  61. <para>image</para>
  62. </listitem>
  63. <listitem>
  64. <para>password</para>
  65. </listitem>
  66. <listitem>
  67. <para>radio</para>
  68. </listitem>
  69. <listitem>
  70. <para>reset</para>
  71. </listitem>
  72. <listitem>
  73. <para>select (régulier ou à selection multiple)</para>
  74. </listitem>
  75. <listitem>
  76. <para>submit</para>
  77. </listitem>
  78. <listitem>
  79. <para>text</para>
  80. </listitem>
  81. <listitem>
  82. <para>textarea</para>
  83. </listitem>
  84. </itemizedlist>
  85. <para>
  86. Vous avez 2 manières de procéder pour ajouter les éléments au formulaire :
  87. instanciez vous même les objets des éléments, ou passer le type d'élément à
  88. <classname>Zend_Form</classname>, qui va alors créer le bon objet pour vous.
  89. </para>
  90. <para>Quelques exemples&#160;:</para>
  91. <programlisting language="php"><![CDATA[
  92. // Ajout d'un objet élément :
  93. $form->addElement(new Zend_Form_Element_Text('username'));
  94. // Passage d'un texte décrivant le futur objet élément, à Zend_Form :
  95. $form->addElement('text', 'username');
  96. ]]></programlisting>
  97. <para>
  98. Par défaut, ces éléments n'ont ni validateurs, ni filtres. Vous devrez donc
  99. ajoutez des validateurs et/ou des filtres, manuellement. Ceci est possible soit (a)
  100. avant de passer l'élément au formulaire, (b) via les options de configuration passés
  101. lors de la création de l'élément, ou (c) en récupérant l'objet déjà enregistré, depuis
  102. le formulaire, et en le configurant ensuite.
  103. </para>
  104. <para>
  105. Voyons comment passer un validateur à un élément dont nous créons l'objet. On peut
  106. passer soit l'objet <classname>Zend_Validate_*</classname>, soit une chaîne le
  107. décrivant&#160;:
  108. </para>
  109. <programlisting language="php"><![CDATA[
  110. $username = new Zend_Form_Element_Text('username');
  111. // Passage d'un objet Zend_Validate_*:
  112. $username->addValidator(new Zend_Validate_Alnum());
  113. // Passage du nom du validateur:
  114. $username->addValidator('alnum');
  115. ]]></programlisting>
  116. <para>
  117. En utilisant la technique de passage par le nom, vous pouvez ajouter un tableau
  118. d'options à passer au constructeur de l'objet validateur. Ceci se fait en troisième
  119. paramètre&#160;:
  120. </para>
  121. <programlisting language="php"><![CDATA[
  122. // Passage d'options au validateur
  123. $username->addValidator('regex', false, array('/^[a-z]/i'));
  124. ]]></programlisting>
  125. <para>
  126. (Le second paramètre permet d'indiquer au validateur s'il doit briser la chaîne de
  127. validation ou non. Par défaut, <constant>FALSE</constant> : ce n'est donc pas le cas.)
  128. </para>
  129. <para>
  130. Vous pouvez avoir besoin de spécifier qu'un élément est requis. Ceci peut être
  131. fait en utilisant un accesseur ou en passant une option à la création de l'élément.
  132. Voici un exemple&#160;:
  133. </para>
  134. <programlisting language="php"><![CDATA[
  135. // Cet élément est requis:
  136. $username->setRequired(true);
  137. ]]></programlisting>
  138. <para>
  139. Lorsqu'un élément est requis, un validateur "NotEmpty" lui est ajouté, sur le
  140. dessus de sa pile de validateurs.
  141. </para>
  142. <para>
  143. La gestion des filtres est très semblable à celle des validateurs. Voyons comment
  144. ajouter un filtre qui retourne la donnée en minuscules :
  145. </para>
  146. <programlisting language="php"><![CDATA[
  147. $username->addFilter('StringtoLower');
  148. ]]></programlisting>
  149. <para>
  150. Finalement, la configuration complète de l'élément pourra ressembler à cela&#160;:
  151. </para>
  152. <programlisting language="php"><![CDATA[
  153. $username->addValidator('alnum')
  154. ->addValidator('regex', false, array('/^[a-z]/'))
  155. ->setRequired(true)
  156. ->addFilter('StringToLower');
  157. // ou, de manière plus compacte:
  158. $username->addValidators(array('alnum',
  159. array('regex', false, '/^[a-z]/i')
  160. ))
  161. ->setRequired(true)
  162. ->addFilters(array('StringToLower'));
  163. ]]></programlisting>
  164. <para>
  165. Aussi simple que cela puisse paraître, cela peut très vite devenir fastidieux de
  166. répéter ces opérations sur tous les éléments du formulaire. Reprenons le cas (b) d'au
  167. dessus : lorsque l'on crée un élément, <methodname>Zend_Form::addElement()</methodname>
  168. agit comme une fabrique et on peut lui passer des options de configuration. Par exemple,
  169. des validateurs ou des filtres. Essayons ceci&#160;:
  170. </para>
  171. <programlisting language="php"><![CDATA[
  172. $form->addElement('text', 'username', array(
  173. 'validators' => array(
  174. 'alnum',
  175. array('regex', false, '/^[a-z]/i')
  176. ),
  177. 'required' => true,
  178. 'filters' => array('StringToLower'),
  179. ));
  180. ]]></programlisting>
  181. <note>
  182. <para>
  183. Si vous vous apercevez que vous créez des éléments basés sur les mêmes
  184. options, étendre <classname>Zend_Form_Element</classname> peut devenir une bonne
  185. option. Votre nouvelle classe configurera directement vos objets.
  186. </para>
  187. </note>
  188. </sect2>
  189. <sect2 id="zend.form.quickstart.render">
  190. <title>Rendre (visuellement) un formulaire</title>
  191. <para>
  192. Rendre un formulaire est très simple. La plupart des éléments nécessitent les
  193. aides de vue <classname>Zend_View</classname> pour être rendus. Ils ont donc besoin d'un
  194. objet de vue. Pour rendre un formulaire, appelez sa méthode <methodname>render()</methodname> ou
  195. faites un <code>echo</code> devant l'objet.
  196. </para>
  197. <programlisting language="php"><![CDATA[
  198. // Appel explicite de render() :
  199. echo $form->render($view);
  200. // Supposant que setView() avec passage d'un objet Zend_View a été appelée avant :
  201. echo $form;
  202. ]]></programlisting>
  203. <para>
  204. Par défaut, <classname>Zend_Form</classname> et les
  205. <classname>Zend_Form_Element</classname> vont essayer de récupérer l'objet de vue depuis
  206. l'aide d'action <code>ViewRenderer</code>, ce qui signifie que vous n'aurez pas besoin
  207. de spécifier un objet de vue manuellement si vous utilisez le système <acronym>MVC</acronym> de Zend
  208. Framework. Pour rendre un formulaire dans une vue <acronym>MVC</acronym>, un simple <code>echo</code>
  209. suffit&#160;:
  210. </para>
  211. <programlisting language="php"><![CDATA[
  212. <?php echo $this->form ?>
  213. ]]></programlisting>
  214. <para>
  215. Techniquement, <classname>Zend_Form</classname> utilise des "décorateurs" pour
  216. effectuer le rendu visuel. Ces décorateurs peuvent remplacer le contenu, ou le placer
  217. avant ou après. Ils peuvent aussi introspecter l'élément qui leur est passé. Ainsi, vous
  218. pouvez chaîner plusieurs décorateurs pour utiliser des effets visuels. Par défaut,
  219. <classname>Zend_Form_Element</classname> combine quatre décorateurs pour
  220. s'afficher&#160;:
  221. </para>
  222. <programlisting language="php"><![CDATA[
  223. $element->addDecorators(array(
  224. 'ViewHelper',
  225. 'Errors',
  226. array('HtmlTag', array('tag' => 'dd')),
  227. array('Label', array('tag' => 'dt')),
  228. ));
  229. ]]></programlisting>
  230. <para>
  231. (Où &lt;HELPERNAME&gt; est le nom de l'aide de vue à utiliser, qui varie selon
  232. l'élément à rendre.)
  233. </para>
  234. <para>
  235. Les décorateurs par défaut (rappelés ci-dessus), produisent le rendu suivant&#160;:
  236. </para>
  237. <programlisting language="html"><![CDATA[
  238. <dt><label for="username" class="required">Username</dt>
  239. <dd>
  240. <input type="text" name="username" value="123-abc" />
  241. <ul class="errors">
  242. <li>'123-abc' has not only alphabetic and digit characters</li>
  243. <li>'123-abc' does not match against pattern '/^[a-z]/i'</li>
  244. </ul>
  245. </dd>
  246. ]]></programlisting>
  247. <para>(Le formatage peut un peu changer.)</para>
  248. <para>
  249. Vous pouvez changer les décorateurs utilisés par un élément si vous voulez avoir
  250. un visuel différent&#160;; voyez la section sur les décorateurs pour plus
  251. d'informations.
  252. </para>
  253. <para>
  254. Le formulaire boucle sur ses éléments et entoure leur rendu d'une balise HTML
  255. <code>&lt;form&gt;</code>. Cette balise prend en compte la méthode, l'action, et les
  256. éventuels attributs passés via <methodname>setAttribs()</methodname>.
  257. </para>
  258. <para>
  259. Les éléments sont bouclés dans l'ordre dans lequel ils sont ajoutés, ou, si votre
  260. élément possède un attribut "order", celui-ci sera alors utilisé pour gérer sa place
  261. dans la pile des éléments&#160;:
  262. </para>
  263. <programlisting language="php"><![CDATA[
  264. $element->setOrder(10);
  265. ]]></programlisting>
  266. <para>Ou encore, à la création de l'élément via <methodname>addElement()</methodname>&#160;:</para>
  267. <programlisting language="php"><![CDATA[
  268. $form->addElement('text', 'username', array('order' => 10));
  269. ]]></programlisting>
  270. </sect2>
  271. <sect2 id="zend.form.quickstart.validate">
  272. <title>Vérifier qu'un formulaire est valide</title>
  273. <para>
  274. Après l'envoi du formulaire, il faut vérifier les valeurs que contiennent ses
  275. éléments. Tous les validateurs de chaque élément sont donc interrogés. Si l'élément
  276. était marqué comme requis et que l'élément ne reçoit aucune donnée, les validateurs
  277. suivants agiront sur une valeur <constant>NULL</constant>.
  278. </para>
  279. <para>
  280. D'où proviennent les données ? Vous pouvez utiliser <varname>$_POST</varname> ou
  281. <varname>$_GET</varname>, ou n'importe quelle source de données (service Web par
  282. exemple)&#160;:
  283. </para>
  284. <programlisting language="php"><![CDATA[
  285. if ($form->isValid($_POST)) {
  286. // succès!
  287. } else {
  288. // echec!
  289. }
  290. ]]></programlisting>
  291. <para>
  292. Avec des requêtes <acronym>AJAX</acronym>, il arrive que l'on ait besoin de ne valider qu'un élément,
  293. ou un groupe d'élément. <methodname>isValidPartial()</methodname> validera un formulaire partiel.
  294. Contrairement à <methodname>isValid()</methodname>, si une valeur est absente, les autres
  295. validateurs ne seront pas interrogés&#160;:
  296. </para>
  297. <programlisting language="php"><![CDATA[
  298. if ($form->isValidPartial($_POST)) {
  299. // Tous les éléments présents dans $_POST ont passé la validation
  300. } else {
  301. // un ou plusieurs éléments présent dans $_POST ont échoué
  302. }
  303. ]]></programlisting>
  304. <para>
  305. La méthode <methodname>processAjax()</methodname> peut aussi être utilisée pour valider
  306. partiellement un formulaire. Contrairement à <methodname>isValidPartial()</methodname>, cette
  307. méthode retournera les messages d'erreur de validation au format <acronym>JSON</acronym>.
  308. </para>
  309. <para>
  310. En supposant que les validateurs aient passé, vous pouvez dès lors récupérer les
  311. valeurs filtrées depuis les éléments&#160;:
  312. </para>
  313. <programlisting language="php"><![CDATA[
  314. $values = $form->getValues();
  315. ]]></programlisting>
  316. <para>Si vous désirez les valeurs non filtrées, utilisez&#160;:</para>
  317. <programlisting language="php"><![CDATA[
  318. $unfiltered = $form->getUnfilteredValues();
  319. ]]></programlisting>
  320. <para>
  321. Si d'un autre côté, vous ne souhaitez que les valeurs filtrées valides d'un formulaire
  322. partiellement valide, vous pouvez appeler&#160;:
  323. </para>
  324. <programlisting language="php"><![CDATA[
  325. $values = $form->getValidValues($_POST);
  326. ]]></programlisting>
  327. </sect2>
  328. <sect2 id="zend.form.quickstart.errorstatus">
  329. <title>Les statuts d'erreur</title>
  330. <para>
  331. Votre formulaire a échoué à l'envoi ? Dans la plupart des cas, vous voudrez rendre
  332. à nouveau le formulaire, mais avec les messages d'erreur affichés&#160;:
  333. </para>
  334. <programlisting language="php"><![CDATA[
  335. if (!$form->isValid($_POST)) {
  336. echo $form;
  337. // ou en assignant un objet de vue (cas non-MVC typiquement)
  338. $this->view->form = $form;
  339. return $this->render('form');
  340. }
  341. ]]></programlisting>
  342. <para>
  343. Si vous voulez inspecter les erreurs, 2 méthodes s'offrent à vous.
  344. <methodname>getErrors()</methodname> retourne un tableau associatif avec en clé le nom de l'élément
  345. et en valeur un tableau de codes d'erreurs. <methodname>getMessages()</methodname> retourne un
  346. tableau associatif avec en clé le nom de l'élément, et en valeur un tableau de messages
  347. d'erreurs (code=&gt;message). Tout élément ne comportant pas d'erreur ne sera pas inclus
  348. dans le tableau.
  349. </para>
  350. </sect2>
  351. <sect2 id="zend.form.quickstart.puttingtogether">
  352. <title>Assembler le tout ensemble</title>
  353. <para>
  354. Créons un formulaire de d'authentification. Il aura besoin d'élément représentant&#160;:
  355. </para>
  356. <itemizedlist>
  357. <listitem>
  358. <para>un nom</para>
  359. </listitem>
  360. <listitem>
  361. <para>un mot de passe</para>
  362. </listitem>
  363. <listitem>
  364. <para>un bouton d'envoi</para>
  365. </listitem>
  366. </itemizedlist>
  367. <para>
  368. Pour notre exemple, imaginons un nom composé de caractères alphanumériques
  369. uniquement. Le nom commencera par une lettre, et devra faire entre 6 et 20 caractères de
  370. long, qui seront normalisés en lettres minuscules. Les mots de passe feront 6 caractères
  371. minimum.
  372. </para>
  373. <para>
  374. Nous allons utiliser la puissance de <classname>Zend_Form</classname> pour
  375. configurer le formulaire et effectuer le rendu&#160;:
  376. </para>
  377. <programlisting language="php"><![CDATA[
  378. $form = new Zend_Form();
  379. $form->setAction('/user/login')
  380. ->setMethod('post');
  381. // élément nom :
  382. $username = $form->createElement('text', 'username');
  383. $username->addValidator('alnum')
  384. ->addValidator('regex', false, array('/^[a-z]+/'))
  385. ->addValidator('stringLength', false, array(6, 20))
  386. ->setRequired(true)
  387. ->addFilter('StringToLower');
  388. // élément mot de passe :
  389. $password = $form->createElement('password', 'password');
  390. $password->addValidator('StringLength', false, array(6))
  391. ->setRequired(true);
  392. // Ajout des éléments au formulaire
  393. $form->addElement($username)
  394. ->addElement($password)
  395. // addElement() agit comme une fabrique qui crée un bouton 'Login'
  396. ->addElement('submit', 'login', array('label' => 'Login'));
  397. ]]></programlisting>
  398. <para>Il nous faut à présent un contrôleur pour gérer tout cela&#160;:</para>
  399. <programlisting language="php"><![CDATA[
  400. class UserController extends Zend_Controller_Action
  401. {
  402. public function getForm()
  403. {
  404. // Créer le formulaire comme décrit ci-dessus
  405. return $form;
  406. }
  407. public function indexAction()
  408. {
  409. // rend user/form.phtml
  410. $this->view->form = $this->getForm();
  411. $this->render('form');
  412. }
  413. public function loginAction()
  414. {
  415. if (!$this->getRequest()->isPost()) {
  416. return $this->_forward('index');
  417. }
  418. $form = $this->getForm();
  419. if (!$form->isValid($_POST)) {
  420. // Validation en echec
  421. $this->view->form = $form;
  422. return $this->render('form');
  423. }
  424. $values = $form->getValues();
  425. // les valeurs sont récupérées
  426. }
  427. }
  428. ]]></programlisting>
  429. <para>Le script de vue pour afficher le formulaire&#160;:</para>
  430. <programlisting language="php"><![CDATA[
  431. <h2>Identifiez vous:</h2>
  432. <?php echo $this->form ?>
  433. ]]></programlisting>
  434. <para>
  435. Comme vous le voyez sur le code du contrôleur, il reste du travail à faire une
  436. fois le formulaire validé. Par exemple, utiliser <classname>Zend_Auth</classname> pour
  437. déclencher un processus d'identification.
  438. </para>
  439. </sect2>
  440. <sect2 id="zend.form.quickstart.config">
  441. <title>Utiliser un objet <classname>Zend_Config</classname></title>
  442. <para>
  443. Toutes les classes du composant <classname>Zend_Form</classname> sont
  444. configurables au moyen d'un objet <classname>Zend_Config</classname> ; vous pouvez
  445. passer un objet <classname>Zend_Config</classname> au constructeur ou via la méthode
  446. <methodname>setConfig()</methodname>. Voyons comment créer le formulaire ci-dessus, au moyen d'un
  447. fichier <acronym>INI</acronym>. Tout d'abord, nous nous baserons sur une section "developement", et nos
  448. instructions devront être imbriquées afin de refléter la configuration. Ensuite nous
  449. utiliserons un espace de nom "user" correspondant au contrôleur, puis un "login"
  450. concernant le formulaire (ceci permet de ranger les données correctement dans le fichier
  451. <acronym>INI</acronym>)&#160;:
  452. </para>
  453. <programlisting language="ini"><![CDATA[
  454. [development]
  455. ; informations générales du formulaire
  456. user.login.action = "/user/login"
  457. user.login.method = "post"
  458. ; element username
  459. user.login.elements.username.type = "text"
  460. user.login.elements.username.options.validators.alnum.validator = "alnum"
  461. user.login.elements.username.options.validators.regex.validator = "regex"
  462. user.login.elements.username.options.validators.regex.options.pattern = "/^[a-z]/i"
  463. user.login.elements.username.options.validators.strlen.validator = "StringLength"
  464. user.login.elements.username.options.validators.strlen.options.min = "6"
  465. user.login.elements.username.options.validators.strlen.options.max = "20"
  466. user.login.elements.username.options.required = true
  467. user.login.elements.username.options.filters.lower.filter = "StringToLower"
  468. ; element password
  469. user.login.elements.password.type = "password"
  470. user.login.elements.password.options.validators.strlen.validator = "StringLength"
  471. user.login.elements.password.options.validators.strlen.options.min = "6"
  472. user.login.elements.password.options.required = true
  473. ; element submit
  474. user.login.elements.submit.type = "submit"
  475. ]]></programlisting>
  476. <para>Le constructeur du formulaire ressemblera alors à ceci&#160;:</para>
  477. <programlisting language="php"><![CDATA[
  478. $config = new Zend_Config_Ini($configFile, 'development');
  479. $form = new Zend_Form($config->user->login);
  480. ]]></programlisting>
  481. <para>et tout le formulaire sera défini.</para>
  482. </sect2>
  483. <sect2 id="zend.form.quickstart.conclusion">
  484. <title>Conclusion</title>
  485. <para>
  486. Vous êtes maintenant capable de libérer la puissance de
  487. <classname>Zend_Form</classname>. Continuez de lire les chapitres suivants pour utiliser
  488. ce composant en profondeur&#160;!
  489. </para>
  490. </sect2>
  491. </sect1>