Zend_Form-QuickStart.xml 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <!-- EN-Revision: 15103 -->
  3. <!-- Reviewed: no -->
  4. <sect1 id="zend.form.quickstart">
  5. <title>Inicio rápido a Zend_Form</title>
  6. <para> Esta guía rápida pretende cubrir los fundamentos para crear, validar
  7. y presentar formularios usando <classname>Zend_Form</classname>
  8. </para>
  9. <sect2 id="zend.form.quickstart.create">
  10. <title>Creando un objeto formulario</title>
  11. <para> Crear un objeto de formulario es muy simple: solo instancíe
  12. <classname>Zend_Form</classname>
  13. </para>
  14. <programlisting language="php"><![CDATA[
  15. $form = new Zend_Form;
  16. ]]></programlisting>
  17. <para> Para casos de uso avanzados, es posible desee crear una subclase
  18. de <classname>Zend_Form</classname>, pero para formularios simples,
  19. puede programar la creación de un formulario usando un objeto
  20. <classname>Zend_Form</classname>
  21. </para>
  22. <para> Si desea especificar el action y method del formulario (siempre
  23. buenas ideas), puede hacer uso de los accesos
  24. <methodname>setAction()</methodname> y
  25. <methodname>setMethod()</methodname>: </para>
  26. <programlisting language="php"><![CDATA[
  27. $form->setAction('/resource/process')
  28. ->setMethod('post');
  29. ]]></programlisting>
  30. <para> El código de arriba establece el action del formulario a la URL
  31. parcial "/resource/process" y como method HTTP POST. Esto se
  32. mostrará en la presentación final. </para>
  33. <para> Usted puede establecer atributos HTML adicionales para la
  34. etiqueta <methodname>&lt;form&gt;</methodname> mediante el
  35. uso de los métodos setAttrib() o setAttribs(). Por ejemplo, si desea
  36. especificar el id establezca el atributo "id": </para>
  37. <programlisting language="php"><![CDATA[
  38. $form->setAttrib('id', 'login');
  39. ]]></programlisting>
  40. </sect2>
  41. <sect2 id="zend.form.quickstart.elements">
  42. <title>Añadir elementos al formulario</title>
  43. <para> Un formulario no es nada sin sus elementos.
  44. <classname>Zend_Form</classname> contiene de manera
  45. predeterminada algunos elementos que generan XHTML vía auxiliares
  46. <classname>Zend_View</classname>. Son los siguientes: </para>
  47. <itemizedlist>
  48. <listitem>
  49. <para> button </para>
  50. </listitem>
  51. <listitem>
  52. <para> checkbox (o varios checkboxes a la vez con multiCheckbox)
  53. </para>
  54. </listitem>
  55. <listitem>
  56. <para> hidden </para>
  57. </listitem>
  58. <listitem>
  59. <para> image </para>
  60. </listitem>
  61. <listitem>
  62. <para> password </para>
  63. </listitem>
  64. <listitem>
  65. <para> radio </para>
  66. </listitem>
  67. <listitem>
  68. <para> reset </para>
  69. </listitem>
  70. <listitem>
  71. <para> select (tanto regulares como de multi-selección) </para>
  72. </listitem>
  73. <listitem>
  74. <para> submit </para>
  75. </listitem>
  76. <listitem>
  77. <para> text </para>
  78. </listitem>
  79. <listitem>
  80. <para> textarea </para>
  81. </listitem>
  82. </itemizedlist>
  83. <para> Tiene dos opciones para añadir elementos a un formulario; puede
  84. instanciar elementos concretos y pasarlos como objetos, o
  85. simplemente puede pasar el tipo de elemento y
  86. <classname>Zend_Form</classname> instaciará por usted un objeto
  87. del tipo correspondiente. </para>
  88. <para> Algunos ejemplos: </para>
  89. <programlisting language="php"><![CDATA[
  90. // Instanciando un elemento y pasandolo al objeto form:
  91. $form->addElement(new Zend_Form_Element_Text('username'));
  92. // Pasando el tipo de elemento del formulario al objeto form:
  93. $form->addElement('text', 'username');
  94. ]]></programlisting>
  95. <para> De manera predeterminada, éstos no tienen validadores o filtros.
  96. Esto significa que tendrá que configurar sus elementos con un mínimo
  97. de validadores, y potencialmente filtros. Puede hacer esto (a) antes
  98. de pasar el elemento al formulario, (b) vía opciones de
  99. configuración pasadas cuando crea un elemento a través de
  100. <classname>Zend_Form</classname>, o (c) recuperar el elemento
  101. del objeto form y configurándolo posteriormente. </para>
  102. <para> Veamos primero la creación de validadores para la instancia de un
  103. elemento concreto. Puede pasar objetos
  104. <classname>Zend_Validate_*</classname> o el nombre de un
  105. validador para utilizar: </para>
  106. <programlisting language="php"><![CDATA[
  107. $username = new Zend_Form_Element_Text('username');
  108. // Pasando un objeto Zend_Validate_*:
  109. $username->addValidator(new Zend_Validate_Alnum());
  110. // Pasando el nombre de un validador:
  111. $username->addValidator('alnum');
  112. ]]></programlisting>
  113. <para> Cuando se utiliza esta segunda opción, si el constructor del
  114. validador acepta argumentos, se pueden pasar en un array como tercer
  115. parámetro: </para>
  116. <programlisting language="php"><![CDATA[
  117. // Pasando un patrón
  118. $username->addValidator('regex', false, array('/^[a-z]/i'));
  119. ]]></programlisting>
  120. <para> (El segundo parámetro se utiliza para indicar si el fallo debería
  121. prevenir la ejecución de validadores posteriores o no; por defecto,
  122. el valor es false.) </para>
  123. <para> Puede también desear especificar un elemento como requerido. Esto
  124. puede hacerse utilizando un método de acceso o pasando una opción al
  125. crear el elemento. En el primer caso: </para>
  126. <programlisting language="php"><![CDATA[
  127. // Hace este elemento requerido:
  128. $username->setRequired(true);
  129. ]]></programlisting>
  130. <para> Cuando un elemento es requerido, un validador 'NotEmpty'
  131. (NoVacio) es añadido a la parte superior de la cadena de
  132. validaciones, asegurando que el elemento tenga algún valor cuando
  133. sea requerido. </para>
  134. <para> Los filtros son registrados básicamente de la misma manera que
  135. los validadores. Para efectos ilustrativos, vamos a agregar un
  136. filtro para poner en minúsculas el valor final: </para>
  137. <programlisting language="php"><![CDATA[
  138. $username->addFilter('StringtoLower');
  139. ]]></programlisting>
  140. <para> Entonces, la configuración final de nuestro elemento queda así: </para>
  141. <programlisting language="php"><![CDATA[
  142. $username->addValidator('alnum')
  143. ->addValidator('regex', false, array('/^[a-z]/'))
  144. ->setRequired(true)
  145. ->addFilter('StringToLower');
  146. // o, de manera más compacta:
  147. $username->addValidators(array('alnum',
  148. array('regex', false, '/^[a-z]/i')
  149. ))
  150. ->setRequired(true)
  151. ->addFilters(array('StringToLower'));
  152. ]]></programlisting>
  153. <para> Tan simple como esto, realizarlo para cada uno de los elementos
  154. del formulario puede resultar un poco tedioso. Intentemos la opción
  155. (b) arriba mencionada. Cuando creamos un nuevo elemento utilizando
  156. <classname>Zend_Form::addElement()</classname> como fábrica,
  157. opcionalmente podemos pasar las opciones de configuración. Éstas
  158. pueden incluir validadores y los filtros que se van a utilizar. Por
  159. lo tanto, para hacer todo lo anterior implícitamente, intente lo
  160. siguiente: </para>
  161. <programlisting language="php"><![CDATA[
  162. $form->addElement('text', 'username', array(
  163. 'validators' => array(
  164. 'alnum',
  165. array('regex', false, '/^[a-z]/i')
  166. ),
  167. 'required' => true,
  168. 'filters' => array('StringToLower'),
  169. ));
  170. ]]></programlisting>
  171. <note>
  172. <para> Si encuentra que está asignando elementos con las mismas
  173. opciones en varios lugares, podría considerar crear su propia
  174. subclase de <classname>Zend_Form_Element</classname> y utilizar
  175. ésta; a largo plazo le permitirá escribir menos. </para>
  176. </note>
  177. </sect2>
  178. <sect2 id="zend.form.quickstart.render">
  179. <title>Generar un formulario</title>
  180. <para> Generar un formulario es simple. La mayoría de los elementos
  181. utilizan un auxiliar de <classname>Zend_View</classname> para
  182. generarse a sí mismos, por lo tanto necesitan un objeto vista con el
  183. fin de generarse. Además, tiene dos opciones: usar el método
  184. render() del formulario, o simplemente mostrarlo con echo. </para>
  185. <programlisting language="php"><![CDATA[
  186. // Llamando a render() explicitamente, y pasando un objeto vista opcional:
  187. echo $form->render($view);
  188. // Suponiendo un objeto vista ha sido previamente establecido vía setView():
  189. echo $form;
  190. ]]></programlisting>
  191. <para> De manera predeterminada, <classname>Zend_Form</classname> y
  192. <classname>Zend_Form_Element</classname> intentarán utilizar el
  193. objeto vista inicializado en el
  194. <methodname>ViewRenderer</methodname>, lo que significa que no
  195. tendrá que establecer la vista manualmente cuando use el MVC de Zend
  196. Framework. Generar un formulario en un script vista es tan simple
  197. como: </para>
  198. <programlisting language="php"><![CDATA[
  199. <?php echo $this->form
  200. ]]></programlisting>
  201. <para> Detrás del telón, <classname>Zend_Form</classname> utiliza
  202. "decoradores" (decorators) para generar la salida. Estos decoradores
  203. pueden reemplazar, añadir o anteponer contenido, y tienen plena
  204. introspección al elemento que les es pasado. Como resultado, puede
  205. combinar múltiples decoradores para lograr efectos personalizados.
  206. Predeterminadamente, <classname>Zend_Form_Element</classname>
  207. actualmente combina cuatro decoradores para obtener su salida; la
  208. configuración sería como sigue: </para>
  209. <programlisting language="php"><![CDATA[
  210. $element->addDecorators(array(
  211. 'ViewHelper',
  212. 'Errors',
  213. array('HtmlTag', array('tag' => 'dd')),
  214. array('Label', array('tag' => 'dt')),
  215. ));
  216. ]]></programlisting>
  217. <para> (Donde &lt;HELPERNAME&gt; es el nombre de un view helper
  218. que utilizar, y varía según el elemento) </para>
  219. <para> Lo anterior crea una salida como la siguiente: </para>
  220. <programlisting language="html"><![CDATA[
  221. <dt><label for="username" class="required">Username</dt>
  222. <dd>
  223. <input type="text" name="username" value="123-abc" />
  224. <ul class="errors">
  225. <li>'123-abc' has not only alphabetic and digit characters</li>
  226. <li>'123-abc' does not match against pattern '/^[a-z]/i'</li>
  227. </ul>
  228. </dd>
  229. ]]></programlisting>
  230. <para> (Aunque no con el mismo formato.) </para>
  231. <para> Puede cambiar los decoradores usados para un elemento si desea
  232. tener diferente salida; véase la sección sobre decoradores para
  233. mayor información. </para>
  234. <para> El propio formulario simplemente itera sobre los elementos y los
  235. cubre en un &lt;form&gt; HTML. El action y method que
  236. proporcionó cuando definió el formulario se pasan a la etiqueta
  237. <methodname>&lt;form&gt;</methodname>, como cualquier
  238. atributo que establezca vía <methodname>setAttribs()</methodname> y
  239. familia. </para>
  240. <para> Elementos son desplegados en el orden en el que fueron
  241. registrados, o, si el elemento contienen un atributo de orden, ese
  242. orden será utilizado. Usted puede fijar el orden de un elemento
  243. usando: </para>
  244. <programlisting language="php"><![CDATA[
  245. $element->setOrder(10);
  246. ]]></programlisting>
  247. <para> O, cuando crea un elemento, pasándolo como una opción: </para>
  248. <programlisting language="php"><![CDATA[
  249. $form->addElement('text', 'username', array('order' => 10));
  250. ]]></programlisting>
  251. </sect2>
  252. <sect2 id="zend.form.quickstart.validate">
  253. <title>Comprobar si un formulario es válido</title>
  254. <para> Después que un formulario es enviado, necesitará comprobar y ver
  255. si pasa las validaciones. Cada elemento es valuado contra los datos
  256. provistos; si una clave no está presente y el campo fue marcado como
  257. requerido, la validación se ejecuta contra un valor nulo. </para>
  258. <para> ¿De dónde provienen los datos?. Puede usar
  259. <methodname>$_POST</methodname> o
  260. <methodname>$_GET</methodname>, o cualquier otra fuente de datos que
  261. tenga a mano (solicitud de un servicio web, por ejemplo): </para>
  262. <programlisting language="php"><![CDATA[
  263. if ($form->isValid($_POST)) {
  264. // ¡Correcto!
  265. } else {
  266. // ¡Fallo!
  267. }
  268. ]]></programlisting>
  269. <para> Con solicitudes AJAX, a veces puede ignorar la validación de un
  270. solo elemento, o grupo de elementos.
  271. <methodname>isValidPartial()</methodname> validará parcialmente
  272. el formulario. A diferencia de <methodname>isValid()</methodname>,
  273. que como sea, si alguna clave no esta presente, no ejecutará las
  274. validaciones para ese elemento en particular. </para>
  275. <programlisting language="php"><![CDATA[
  276. if ($form->isValidPartial($_POST)) {
  277. // de los elementos presentes, todos pasaron las validaciones
  278. } else {
  279. // uno u más elementos probados no pasaron las validaciones
  280. }
  281. ]]></programlisting>
  282. <para> Un método adicional, <methodname>processAjax()</methodname>,
  283. puede también ser usado para validar formularios parciales. A
  284. diferencia de <methodname>isValidPartial()</methodname>, regresa una
  285. cadena en formato JSON conteniendo mensajes de error en caso de
  286. fallo. </para>
  287. <para> Asumiendo que sus validaciones han pasado, ahora puede obtener
  288. los valores filtrados: </para>
  289. <programlisting language="php"><![CDATA[
  290. $values = $form->getValues();
  291. ]]></programlisting>
  292. <para> Si necesita los valores sin filtrar en algún punto, utilice: </para>
  293. <programlisting language="php"><![CDATA[
  294. $unfiltered = $form->getUnfilteredValues();
  295. ]]></programlisting>
  296. </sect2>
  297. <sect2 id="zend.form.quickstart.errorstatus">
  298. <title>Obteniendo el estado de error</title>
  299. <para> Entonces, ¿su formulario no es válido? En la mayoría de los
  300. casos, simplemente puede generar el formulario nuevamente y los
  301. errores se mostrarán cuando se usen los decoradores predeterminados: </para>
  302. <programlisting language="php"><![CDATA[
  303. if (!$form->isValid($_POST)) {
  304. echo $form;
  305. // o asigne al objeto vista y genere una vista...
  306. $this->view->form = $form;
  307. return $this->render('form');
  308. }
  309. ]]></programlisting>
  310. <para> Si quiere inspeccionar los errores, tiene dos métodos.
  311. <methodname>getErrors()</methodname> regresa una matriz
  312. asociativa de nombres / códigos de elementos (donde códigos es una
  313. matriz de códigos de error). <methodname>getMessages()</methodname>
  314. regresa una matriz asociativa de nombres / mensajes de elementos
  315. (donde mensajes es una matriz asociativa de pares código de error /
  316. mensaje de error). Si un elemento no tiene ningún error, no será
  317. incluido en la matriz. </para>
  318. </sect2>
  319. <sect2 id="zend.form.quickstart.puttingtogether">
  320. <title>Poniendo todo junto</title>
  321. <para> Construyamos un simple formulario de login. Necesitaremos
  322. elementos que representen: </para>
  323. <itemizedlist>
  324. <listitem>
  325. <para>usuario</para>
  326. </listitem>
  327. <listitem>
  328. <para>contraseña</para>
  329. </listitem>
  330. <listitem>
  331. <para>Botón de ingreso</para>
  332. </listitem>
  333. </itemizedlist>
  334. <para> Para nuestros propósitos, vamos a suponer que un usuario válido
  335. cumplirá con tener solo caracteres alfanuméricos, comenzar con una
  336. letra, tener una longitud mínima de 6 caracteres y una longitud
  337. máxima de 20 caracteres; se normalizarán en minúsculas. Las
  338. contraseñas deben tener un mínimo de 6 caracteres. Cuando se procese
  339. vamos simplemente a mostrar el valor, por lo que puede permanecer
  340. inválido. </para>
  341. <para> Usaremos el poder de la opciones de configuración de
  342. <classname>Zend_Form</classname> para crear el formulario: </para>
  343. <programlisting language="php"><![CDATA[
  344. $form = new Zend_Form();
  345. $form->setAction('/user/login')
  346. ->setMethod('post');
  347. // Crea un y configura el elemento username
  348. $username = $form->createElement('text', 'username');
  349. $username->addValidator('alnum')
  350. ->addValidator('regex', false, array('/^[a-z]+/'))
  351. ->addValidator('stringLength', false, array(6, 20))
  352. ->setRequired(true)
  353. ->addFilter('StringToLower');
  354. // Crea y configura el elemento password:
  355. $password = $form->createElement('password', 'password');
  356. $password->addValidator('StringLength', false, array(6))
  357. ->setRequired(true);
  358. // Añade los elementos al formulario:
  359. $form->addElement($username)
  360. ->addElement($password)
  361. // uso de addElement() como fábrica para crear el botón 'Login':
  362. ->addElement('submit', 'login', array('label' => 'Login'));
  363. ]]></programlisting>
  364. <para> A continuación, vamos a crear un controlador para manejar esto: </para>
  365. <programlisting language="php"><![CDATA[
  366. class UserController extends Zend_Controller_Action
  367. {
  368. public function getForm()
  369. {
  370. // crea el formulario como se indicó arriba
  371. return $form;
  372. }
  373. public function indexAction()
  374. {
  375. // genera user/form.phtml
  376. $this->view->form = $this->getForm();
  377. $this->render('form');
  378. }
  379. public function loginAction()
  380. {
  381. if (!$this->getRequest()->isPost()) {
  382. return $this->_forward('index');
  383. }
  384. $form = $this->getForm();
  385. if (!$form->isValid($_POST)) {
  386. // Falla la validación; Se vuelve a mostrar el formulario
  387. $this->view->form = $form;
  388. return $this->render('form');
  389. }
  390. $values = $form->getValues();
  391. // ahora intenta y autentica...
  392. }
  393. }
  394. ]]></programlisting>
  395. <para> Y un script para la vista que muestra el formulario: </para>
  396. <programlisting language="php"><![CDATA[
  397. <h2>Please login:</h2>
  398. <?php echo $this->form
  399. ]]></programlisting>
  400. <para> Como notará en el código del controlador, hay más trabajo por
  401. hacer: mientras la información enviada sea válida, necesitará
  402. todavía realizar la autenticación usando
  403. <methodname>Zend_Auth</methodname>, por ejemplo. </para>
  404. </sect2>
  405. <sect2 id="zend.form.quickstart.config">
  406. <title>Usando un objeto Zend_Config</title>
  407. <para> Todas las clases <classname>Zend_Form</classname> son
  408. configurables mediante <classname>Zend_Config</classname>; puede
  409. incluso pasar un objeto al constructor o pasarlo a través de
  410. <methodname>setConfig()</methodname>. Veamos cómo podemos crear
  411. el formulario anterior usando un archivo INI. Primero, vamos a
  412. seguir las recomendaciones, y colocaremos nuestras configuraciones
  413. dentro de secciones reflejando su objetivo y y enfocándonos en la
  414. sección 'development'. A continuación, pondremos en una sección de
  415. configuración para el controlador dado ('user'), y una clave para el
  416. formulario ('login'): </para>
  417. <programlisting language="ini"><![CDATA[
  418. [development]
  419. ; metainformación general del formulario
  420. user.login.action = "/user/login"
  421. user.login.method = "post"
  422. ; elemento username
  423. user.login.elements.username.type = "text"
  424. user.login.elements.username.options.validators.alnum.validator = "alnum"
  425. user.login.elements.username.options.validators.regex.validator = "regex"
  426. user.login.elements.username.options.validators.regex.options.pattern = "/^[a-z]/i"
  427. user.login.elements.username.options.validators.strlen.validator = "StringLength"
  428. user.login.elements.username.options.validators.strlen.options.min = "6"
  429. user.login.elements.username.options.validators.strlen.options.max = "20"
  430. user.login.elements.username.options.required = true
  431. user.login.elements.username.options.filters.lower.filter = "StringToLower"
  432. ; elemento password
  433. user.login.elements.password.type = "password"
  434. user.login.elements.password.options.validators.strlen.validator = "StringLength"
  435. user.login.elements.password.options.validators.strlen.options.min = "6"
  436. user.login.elements.password.options.required = true
  437. ; elemento submit
  438. user.login.elements.submit.type = "submit"
  439. ]]></programlisting>
  440. <para> Entonces puede pasarlo al constructor del formulario: </para>
  441. <programlisting language="php"><![CDATA[
  442. $config = new Zend_Config_Ini($configFile, 'development');
  443. $form = new Zend_Form($config->user->login);
  444. ]]></programlisting>
  445. <para> y el formulario entero será definido. </para>
  446. </sect2>
  447. <sect2 id="zend.form.quickstart.conclusion">
  448. <title>Conclusión</title>
  449. <para> Esperamos que después de este pequeño tutorial sea capaz de
  450. descubrir el poder y flexibilidad de
  451. <classname>Zend_Form</classname>. Continúe leyendo para
  452. profundizar más en el tema. </para>
  453. </sect2>
  454. </sect1>