Formularios
Los formularios nos permiten pedirle información a los usuarios.
Un formulario se crea con la etiqueta
<form>
:<form>
</form>
Un formulario puede tener muchos elementos de entrada como campos de texto, casillas de verificación (checkbox), listas desplegables, botones de envío y muchos más. Veamos algunos de ellos:
Para definir un campo de texto utiliza la etiqueta
<input type="text">
.<form>
<input type="text">
</form>
Los campos de contraseña son similares a los campos de texto pero el texto se reemplaza automáticamente por asteriscos (
*
) cuando la persona escribe.Para definir un campo de contraseña utiliza la etiqueta
<input type="password">
.<form>
<input type="password">
</form>
Para definir una casilla de verificación utiliza la etiqueta
<input type="checkbox">
:<form>
<input type="checkbox"> Acepto recibir información
</form>
El botón de envío, como su nombre lo indica, se utiliza para enviar la información que ha ingresado el usuario a un servidor remoto.
Para definir un botón de envío utiliza la etiqueta
<input type="submit" value="Enviar">
:<form>
<input type="submit" value="Enviar">
</form>
El atributo
value
define el texto del botón.Para utilizar un botón de envío necesitas también definir al menos:
- 1.La URL del servidor al que quieres enviar la información en el atributo
action
. - 2.Agregar un atributo
name
a todos los campos de entrada que quieres enviar al servidor.
Por ejemplo:
<form action="http://mi-empresa.com/contacto">
<div>
Nombre: <input type="text" name="nombre">
</div>
<div>
Mensaje: <input type="text" name="mensaje">
</div>
<input type="submit" value="Enviar">
</form>
Es buena práctica utilizar una etiqueta
<label>
para encerrar el texto que se va a mostrar para cada campo de entrada.Para relacionar el
<label>
al campo de entrada debes:- Agregar un atributo
id
al campo de entrada. - Agregar un atributo
for
al<label>
con el mismo valor del atributoid
del campo de entrada.
Por ejemplo:
<form>
<label for="nombre">Nombre:</label> <input type="text" id="nombre" name="nombre">
</form>
La ventaja de utilizar un label es que si hacen click sobre el label se va a enfocar automáticamente el campo de entrada. Esto es especialmente útil en casillas de verificación y botones de radio.
Para definir un botón de radio utiliza la etiqueta
<input type="radio">
:<form>
<input type="radio">
</form>
Los botones de radio son especialmente útiles para que el usuario escoja una única opción. Por ejemplo:
<form action="/accion">
<div>
<label for="masculino">Masculino</label>
<input type="radio" name="genero" id="masculino" value="masculino">
</div>
<div>
<label for="femenino">Femenino</label>
<input type="radio" name="genero" id="femenino" value="femenino">
</div>
<div>
<label for="otro">Otro</label>
<input type="radio" name="genero" id="otro" value="otro">
</div>
<input type="submit" value="Enviar">
</form>
Fíjate en lo siguiente:
- El valor del atributo
name
esgenero
en todos los botones de radio. - Cada botón de radio tiene un atributo
value
con un valor distinto.
Es decir, que al servidor va a llegar el
genero
con el valor del botón de radio que haya seleccionado el usuario (masculino
, femenino
u otro
).Las áreas de texto son similares a los campos de texto pero pueden ser de múltiples líneas.
Para crear un área de texto se utiliza la etiqueta
<textarea>
:<form>
<textarea rows="5"></textarea>
</form>
Nota: a diferencia de la etiqueta
<input>
, la etiqueta <textarea>
necesita una etiqueta de cierre.Para crear una lista de selección utiliza la etiqueta
<select>
:<form>
<select name="genero">
<option value="masculino">Masculino</option>
<option value="femenino">Femenino</option>
</select>
</form>
Last modified 2mo ago