Curso gratuito de HTML. Regístrate para hacer un seguimiento de tu progreso →

HTML: Campo de texto

El elemento principal de los formularios en HTML es el campo de texto. Se implementa utilizando la etiqueta <input> y permite definir diferentes tipos de campos de entrada de datos: texto, contraseñas, casillas de verificación, botones de radio, botones de envío, carga de archivos, entrada de fechas, entre otros.

A partir de HTML5, la lista de campos se ha ampliado con muchas opciones nuevas. Los tipos básicos de campos de entrada son:

La forma más sencilla de utilizar <input> es crear un campo de texto para la entrada. Es precisamente <input> el que se encuentra en todos los campos de búsqueda. Para crear un campo de texto simple, simplemente agrega la etiqueta <input> sin pareja dentro del formulario y especifica el atributo type con el valor text:

<form>
  <input type="text">
</form>

Etiqueta label

El campo está creado, pero no está claro qué se debe ingresar allí: ¿nombre, apellido, código de la caja fuerte? Para indicar el propósito del campo, se utiliza la etiqueta <label>. Esta es una etiqueta de pareja que se asemeja a un párrafo, pero se refiere específicamente a la descripción del campo del formulario.

<form>
  <label>Ingrese su nombre</label>
  <input type="text">
</form>

En realidad, no es suficiente simplemente especificar label, es necesario vincularlo al campo del formulario. Esto es necesario para una asociación unívoca, ya que puede haber muchos campos.

Para vincular label, se utiliza una de las dos opciones:

<form>
  <label for="name">Ingrese su nombre</label>
  <input type="text" id="name">
</form>
<form>
  <label>Ingrese su nombre
    <input type="text">
  </label>
</form>

Atributo placeholder

A veces hay situaciones en las que hay una descripción para el campo, pero no está claro en qué formato se deben completar los datos. Por ejemplo, ¿primero se debe ingresar el nombre y luego el apellido, o viceversa? Para ayudar al usuario a orientarse, se utiliza el atributo placeholder en la etiqueta <input>. El valor de este atributo se mostrará dentro del campo de texto.

<form>
  <label for="name">Ingrese su nombre y apellido</label>
  <input type="text" id="name" placeholder="Iván Ivánov">
</form>

Otros campos de texto

¿Has notado que al ingresar contraseñas, el navegador automáticamente muestra asteriscos en lugar de los caracteres? Esto se puede lograr especificando el valor password para el atributo type:

<form>
  <label for="pin">Ingrese su código PIN</label>
  <input type="password" id="pin" placeholder="1234">
</form>

En HTML5 se han agregado varios tipos interesantes más para la etiqueta <input>, que implementan un campo de texto normal pero con su propia implementación. Por ejemplo:

Su propósito es que los valores se verifiquen automáticamente por el navegador. Por ejemplo, si se ingresa el valor email, el navegador esperará una plantilla correcta para una dirección de correo electrónico. De lo contrario, indicará que el valor es incorrecto al intentar enviar el formulario.

Los dispositivos móviles también tienen en cuenta estos campos. En las versiones modernas de los sistemas operativos móviles, el teclado se adapta al tipo de campo que se está completando. Si se establece el tipo email, se agregará automáticamente el símbolo @ al teclado para no tener que buscarlo entre los caracteres adicionales.

Tarea

Crea un formulario cuyo archivo de procesamiento de datos se encuentre en la dirección /people. Dentro del formulario, crea 2 campos de texto.

¿El ejercicio no pasa la prueba, qué debo hacer? 😶

Si te quedaste atascado, es el momento perfecto para hacer una pregunta en las "Discusiones".
* Asegúrate de incluir la salida de las pruebas. Sin ella, es casi imposible entender qué está mal, incluso si muestras tu código. Los programadores tienen dificultades para ejecutar el código en su mente, pero casi siempre es posible entender a dónde mirar a partir del error que recibiste.

Mi código funciona en mi entorno, pero no aquí 🤨

Las pruebas están diseñadas de manera que verifican la solución de diferentes maneras y con diferentes datos. A menudo, una solución funciona con ciertos datos de entrada pero no con otros. Para entender este punto, revisa la pestaña "Pruebas" y presta atención a los mensajes de error, que suelen contener pistas.

Mi código es diferente a la solución del profesor 🤔

Esto es normal 🙆. En programación, una tarea puede tener muchas soluciones diferentes. Si tu código pasa la prueba, cumple con los requisitos de la tarea.

En raras ocasiones, la solución puede estar ajustada para pasar las pruebas, pero esto suele ser evidente.

Leí la lección, pero no entendí nada 🙄

Crear materiales de aprendizaje comprensibles para todos es bastante difícil. Hacemos nuestro mejor esfuerzo, pero siempre hay margen para mejorar. Si encuentras material que no entiendes, describe el problema en las "Discusiones". Es ideal si puedes formular los aspectos que no entiendes en forma de preguntas. Por lo general, necesitamos unos días para hacer mejoras.

Por cierto, tú también puedes contribuir a mejorar los cursos: en la parte inferior hay un enlace al código fuente de las lecciones, que se puede modificar directamente en el navegador.


¿Encontraste un error? ¿Quieres añadir algo? Las solicitudes de extracción son bienvenidas. https://codica.la/errores
El reactor de código está disponible en la versión principal →