image
Inicio » PHP » Artículos sobre PHP » PHP Perfect Form Items v1.0 (Formularios sin errores)




PHP Perfect Form Items v1.0 (Formularios sin errores)

 
Por Jose Carlos García
Artículos publicados: 1
Valoración media: 3.66/5
Usuario desde: 11/12/2004

¿Cuántas veces que hemos necesitado integrar código PHP con elementos de formularios, hemos conseguido una mezcla de HTML y etiquetas <?php ?> disminuyendo la legibilidad del código o haciendo que tengamos que escribir más lineas de la cuenta?

Con estas sencillas pero útiles funciones podremos sin problemas emplazar campos a los formularios que diseñemos sin tantos quebraderos de cabeza.

Las funciones que se explican en este artículo se encuentran en la siguiente dirección http://www.distintiva.com/jose/_perf_form/perf_form.zip. El código puede ser cambiado, mejorado y distribuido libremente. Ha sido programado totalmente por Jose Carlos García de Distintiva Solutions (www.distintiva.com).

Empecemos con el ejemplo más difícil y el causante de que tuviera que programar estas funciones.

<SELECT>

Crear elementos de selección <select></select>
Con php es muy habitual trabajar con arrays, ya sea con datos que nos proporcione una consulta SQL o simples valores.

Veamos un ejemplo en el que queremos mostrar un <select> para que el usuario seleccione su rango de edad:

<select name="edad">
	<option value=0>Seleccione</option>
	<option value=1>Entre 0-18</option>
	<option value=2>Entre 19-30</option>
	<option value=3>Entre 31-50</option>
	<option value=4>Más de 50</option>
<select/>

Esto se complica cuando hay que hacerlo de forma dinámica ya que esta lista puede variar, para evitar tener que cambiar el HTML “a pelo” ya que necesitamos construir este fragmento de HTML con un bucle, etc.

Se complica aún más cuando una opción debe estar preseleccionada.
La función que nos salvará la vida es:
frm_select($name, $arr_txt, $arr_vals, $default='', $extra_tag='')
$name = Nombre del elemento del formulario
$arr_txt = Array con los textos a mostrar
$arr_vals = Array con los valores asociados a cada texto
$default= [opcional] si se indica el valor aparecerá preseleccionado dicha opción
$extra_tag= [opcional] por si necesitamos incluir información adicional al select, como por ejemplo $extra_tag=” class=cssazul ” o $extra_tag=” onChange=alert()”

Ejemplo:
$arr_txt=array(‘españa’, ‘portugal’, ‘francia’);
$arr_vals=array(‘ES’, ‘PT’, FR’);
<?=frm_select (‘paises’, $arr_txt, $arr_vals) ?>

De esta forma cualquier modificación sólo hay que hacerla en los arrays sin alterar la parte visual.

A veces es conveniente conservar el valor de un campo del formulario entre llamadas o posts del mismo por ejemplo cuando estamos validando entradas y hay que volver al formulario para que rellene algún campo requerido. Para hacer esto de forma sencilla tan solo tenemos que usar el parámetro $default de la siguiente forma:

<?=frm_select (‘paises’, $arr_txt, $arr_vals, $_POST[‘paises’]) ?>
(o $_GET dependiendo el método que usemos en nuestro formulario)

<SELECT> (tipo lista con varios elementos visibles)

Funciona exactamente igual que el anterior pero en este caso tenemos la típica lista de selección con scroll mostrando X elementos.

La función es:
frm_list($name,$size, $arr_txt, $arr_vals, $default='', $extra_tag='')

En este caso el nuevo parámetro es $size que indica cuántos elementos serán mostrados visiblemente en la lista.

<SELECT> (tipo lista con varios elementos visibles y con multiselección)

Igual que el ejemplo anterior pero permitimos que el usuario seleccione uno o varios elementos de la lista con el CTRL+Click o SHIFT+Click

La función es:
frm_list_multi($name, $size, $arr_txt, $arr_vals, $default='', $extra_tag='')

... Y también tenemos funciones correspondientes para los demás elementos de formulario aprovechando la capacidad de mantener el valor entre posts.

<CHECKBOX>

No hace falta decir para que sirven estos elementos. La función es:
frm_check($name, $ck_val, $var_in='', $extra_tag='')
$name= Nombre del campo
$ck_val= Valor que se enviará cuando esté seleccionado
$var_in=[opcional] Funciona como el $default y permitirá que se muestre checkeado

Ejemplo:
Se muestra un checkbox que se mantiene seleccionado entre posts del formulario
<?= frm_check(‘fumador’, ‘SI’, $_POST[‘fumador’])?>


<RADIO>

En este caso para mostrar radiobuttons se hace exactamente como el caso anterior pero con la siguiente función:

frm_radio($name, $val, $var_in='', $extra_tag='')


<INPUT>

Permite mostrar cuadros de texto con las ventajas que voy ofreciendo en todas las funciones y para ello hay que usar:

frm_text($name, $val, $size, $max_length, $extra_tag='')
$name = Nombre del campo
$val = Valor o texto que se mostrará (funciona como el $default de las otras funciones)
$size = Tamaño del campo de texto
$max_length = Longitud máxima permitida


<PASSWORD>

El caso es exactamente como el anterior pero esta vez oculta el texto con asteriscos.

frm_password($name, $val, $size, $max_length, $extra_tag='')





Bio:
Jose Carlos García tiene gran experiencia en desarrollos de aplicaciones para diversas plataformas y tecnologías y coordinación de equipos para puesta en marcha de grandes proyectos. Actualmente dirige el área de nuevas tecnologías de www.distintiva.com

Fecha publicación: 11/12/2004


Más artículos

Valoración

Este artículo ha sido valorado 944 veces. Valor:  [3.66/5]   
Malo------>Normal----->Bueno
                   

Comentarios

Añadir un comentario

Si no está de acuerdo con algo o quiere añadir más información al respecto puede incluirla añadiendo un comentario.

Nombre:
E-Mail: (opcional)
Los comentarios son moderados, no aparecen inmediatamente, son leídos por el administrador y publicados según el interés para otros lectores.

Se reserva el derecho de publicación de los comentarios introducidos.

Colabora

¿Te sientes capacitado para escribir un artículo como este? ¿Te gustaría colaborar escribiendo artículos en WebEstilo? Háznoslo saber !!









Comparte



 
Valid HTML 4.01!
Última modificación:11 de Mayo de 2009. Spain - España.
© 1998-2004 por . Todos los derechos reservados.