El campo de texto es un elemento básico de formulario que permite la inserción y edición de texto en una única línea. Se debe usar cuando el texto a introducir es corto, por ejemplo nombre o apellidos. Para textos largos usar áreas de texto.
Campo de entrada con borde gris de 1px y esquinas redondeadas, fondo blanco. Label en texto negro de peso regular posicionado arriba del input. Altura del campo aproximadamente 35-40px, ancho de 100px.
Mostrar códigodel ejemplo: Por defecto
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Esto es un label"
},
"id": "input-example-a",
"name": "test-name"
}) }}
Campo de entrada con borde gris claro de 1px y esquinas redondeadas, fondo blanco. Label en texto negro de peso regular posicionado arriba del input. Altura del campo aproximadamente 35-40px, ancho de 100px, apariencia visual sin interacción activa.
Campo de entrada con borde gris de 1px y esquinas redondeadas, fondo blanco. Label en texto negro de peso regular arriba, seguido de texto secundario en gris oscuro debajo del label. Campo de entrada con altura aproximadamente 35-40px, ancho de 100px, posicionado debajo del texto secundario.
Esto es una pista.
Mostrar códigodel ejemplo: Con pista
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Esto es un label"
},
"hint": {
"text": "Esto es una pista."
},
"id": "input-with-hint-text",
"name": "test-name"
}) }}
HTML
<!-- input --><divclass="c-form-group"><!-- label --><labelclass="block"for="input-with-hint-text">Esto es un label</label><!-- /label --><!-- hint --><pid="input-with-hint-text-hint"class="block text-neutral-dark">Esto es una pista.</p><!-- /hint --><inputclass="c-input block mt-sm border-black rounded-sm font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base"id="input-with-hint-text"name="test-name"type="text"aria-describedby="input-with-hint-text-hint"></div><!-- /input -->
Por accesibilidad, los mensajes de error deben incluir la palabra "error", para que no recaiga tan sólo en el color el hecho de que es un mensaje de error.
Descripción visual
Campo de entrada de texto con borde rojo de 2px, fondo blanco, y esquinas ligeramente redondeadas. Incluye label negro en peso normal, texto de pista rojo debajo del label, y mensaje de error rojo debajo del campo. Ancho del input es estrecho (aproximadamente 100px).
Esto es una pista.
Error:Esto es un mensaje de error
Mostrar códigodel ejemplo: Con mensaje de error
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Esto es un label"
},
"hint": {
"text": "Esto es una pista."
},
"id": "input-with-error-message-a",
"name": "test-name",
"errorMessage": {
"text": "Esto es un mensaje de error"
}
}) }}
HTML
<!-- input --><divclass="c-form-group c-form-group--error"><!-- label --><labelclass="block"for="input-with-error-message-a">Esto es un label</label><!-- /label --><!-- hint --><pid="input-with-error-message-a-hint"class="block text-neutral-dark">Esto es una pista.</p><!-- /hint --><!-- error-message --><pid="input-with-error-message-a-error"class="block font-semibold text-alert-base"><spanclass="sr-only">Error:</span>Esto es un mensaje de error
</p><!-- /error-message --><inputclass="c-input block mt-sm border-alert-base ring-2 ring-alert-base rounded-sm font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base"id="input-with-error-message-a"name="test-name"type="text"aria-describedby="input-with-error-message-a-hint"aria-errormessage="input-with-error-message-a-error"aria-invalid="true"></div><!-- /input -->
Por accesibilidad, los mensajes de error deben incluir la palabra "error", para que no recaiga tan sólo en el color el hecho de que es un mensaje de error.
Descripción visual
Campo de entrada de texto con borde rojo de 2px, fondo blanco, y esquinas ligeramente redondeadas. Incluye label negro en peso normal arriba, texto de pista rojo debajo del label, y mensaje de error rojo debajo del campo. Ancho del input es estrecho (aproximadamente 100px).
Esto es una pista.
Error:Esto es un mensaje de error
Mostrar códigodel ejemplo: Con mensaje de error con id personalizado
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Esto es un label"
},
"hint": {
"text": "Esto es una pista."
},
"id": "input-with-error-message-b",
"name": "test-name",
"errorId": "custom-error-id",
"errorMessage": {
"text": "Esto es un mensaje de error"
}
}) }}
HTML
<!-- input --><divclass="c-form-group c-form-group--error"><!-- label --><labelclass="block"for="input-with-error-message-b">Esto es un label</label><!-- /label --><!-- hint --><pid="input-with-error-message-b-hint"class="block text-neutral-dark">Esto es una pista.</p><!-- /hint --><!-- error-message --><pid="custom-error-id"class="block font-semibold text-alert-base"><spanclass="sr-only">Error:</span>Esto es un mensaje de error
</p><!-- /error-message --><inputclass="c-input block mt-sm border-alert-base ring-2 ring-alert-base rounded-sm font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base"id="input-with-error-message-b"name="test-name"type="text"aria-describedby="input-with-error-message-b-hint"aria-errormessage="custom-error-id"aria-invalid="true"></div><!-- /input -->
Este ejemplo usa todo el ancho disponible. Mira el archivo tailwind.config.js para una lista completa de anchuras disponibles.
Descripción visual
Campo de entrada de texto con borde gris de 1px, fondo blanco, y esquinas ligeramente redondeadas ocupando el ancho completo del contenedor. Incluye label negro en peso normal arriba y texto de pista gris oscuro debajo del label. El input se extiende horizontalmente de borde a borde del área disponible.
Esto es una pista.
Mostrar códigodel ejemplo: Con clase de anchura completa
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Esto es un label"
},
"hint": {
"text": "Esto es una pista."
},
"id": "input-width-full",
"name": "test-width-full",
"classes": "w-full"
}) }}
HTML
<!-- input --><divclass="c-form-group"><!-- label --><labelclass="block"for="input-width-full">Esto es un label</label><!-- /label --><!-- hint --><pid="input-width-full-hint"class="block text-neutral-dark">Esto es una pista.</p><!-- /hint --><inputclass="c-input block mt-sm border-black rounded-sm font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base w-full"id="input-width-full"name="test-width-full"type="text"aria-describedby="input-width-full-hint"></div><!-- /input -->
Este ejemplo usa la mitad del ancho disponible por su contenedor. Mira el archivo tailwind.config.js para una lista completa de anchuras disponibles.
Descripción visual
Input de texto con borde gris de 1px, fondo blanco, ocupando aproximadamente la mitad del ancho del contenedor. Label en texto negro normal arriba del campo, seguido de texto auxiliar gris claro debajo del label. Campo de entrada rectangular con altura estándar y esquinas ligeramente redondeadas.
Esto es una pista.
Mostrar códigodel ejemplo: Con clase de anchura 1/2
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Esto es un label"
},
"hint": {
"text": "Esto es una pista."
},
"id": "input-width-half",
"name": "test-width-half",
"classes": "w-1/2"
}) }}
HTML
<!-- input --><divclass="c-form-group"><!-- label --><labelclass="block"for="input-width-half">Esto es un label</label><!-- /label --><!-- hint --><pid="input-width-half-hint"class="block text-neutral-dark">Esto es una pista.</p><!-- /hint --><inputclass="c-input block mt-sm border-black rounded-sm font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base w-1/2"id="input-width-half"name="test-width-half"type="text"aria-describedby="input-width-half-hint"></div><!-- /input -->
Este ejemplo usa una anchura predefinida de DESY. Mira el archivo tailwind.config.js para una lista completa de anchuras disponibles
Descripción visual
Input de texto con borde gris de 1px, fondo blanco, ocupando un ancho fijo reducido (aproximadamente 150-200px). Label en texto negro normal posicionado arriba del campo, seguido de texto auxiliar gris claro debajo del label. Campo de entrada rectangular compacto con altura estándar y esquinas ligeramente redondeadas.
Esto es una pista.
Mostrar códigodel ejemplo: Con clase width-32
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Esto es un label"
},
"hint": {
"text": "Esto es una pista."
},
"id": "input-width-32",
"name": "test-width-32",
"classes": "w-32"
}) }}
HTML
<!-- input --><divclass="c-form-group"><!-- label --><labelclass="block"for="input-width-32">Esto es un label</label><!-- /label --><!-- hint --><pid="input-width-32-hint"class="block text-neutral-dark">Esto es una pista.</p><!-- /hint --><inputclass="c-input block mt-sm border-black rounded-sm font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base w-32"id="input-width-32"name="test-width-32"type="text"aria-describedby="input-width-32-hint"></div><!-- /input -->
Input de texto con borde gris de 1px, fondo blanco, dentro de un contenedor con fondo celeste/azul claro que ocupa todo el ancho disponible. Label en texto negro normal posicionado arriba del campo dentro del área celeste. Campo de entrada rectangular con altura estándar, esquinas ligeramente redondeadas, rodeado de padding generoso del contenedor de fondo celeste.
Mostrar códigodel ejemplo: Con clases de form-group opcionales
Campo de entrada de texto con borde gris de 1px y esquinas redondeadas, fondo blanco. Label en texto negro regular posicionado arriba del campo. Dimensiones aproximadas de 100px de ancho por 30px de alto para el input.
Mostrar códigodel ejemplo: Con valores de autocompletado
Usa el atributo pattern para elegir un patrón de entrada de datos nativo del navegador.
Descripción visual
Campo de entrada de texto con borde gris de 1px y esquinas redondeadas, fondo blanco. Label en texto negro regular posicionado arriba del campo. Dimensiones aproximadas de 100px de ancho por 30px de alto para el input.
Mostrar códigodel ejemplo: Con al atributo pattern
El formulario debe comenzar con un párrafo que ponga: * Todos los campos marcados con asterisco son obligatorios.
Descripción visual
Campo de entrada de texto con borde gris de 1px y esquinas redondeadas, fondo blanco. Label en texto negro regular con asterisco rojo posicionado arriba del campo. Dimensiones aproximadas de 100px de ancho por 30px de alto para el input.
Campo de entrada de texto con label "Input peque" en texto negro de peso normal. Borde gris delgado de 1px, fondo blanco, tamaño reducido del input. El campo presenta esquinas ligeramente redondeadas.
Label en linea + Input flexible y mensaje de error
Descripción visual
Campo de entrada de texto con label en texto negro de peso normal. Borde rojo grueso de 2-3px, fondo blanco del input. Mensaje de error en texto rojo debajo del campo.
Error:Esto es un mensaje de error
Mostrar códigodel ejemplo: Con clases de css aplicadas
Si no se espacifica, el tipo por defecto es text. Este Input tiene un type='number'
Descripción visual
Campo de entrada de texto con label en texto negro de peso normal. Borde gris delgado de 1px, fondo blanco, tamaño estándar del input. El campo presenta esquinas ligeramente redondeadas.
Campo de entrada de texto con borde gris de 1px y esquinas redondeadas, fondo blanco. Título en texto negro estándar arriba, seguido de label en negro. Input contiene texto en negro estándar, tamaño mediano.
Mostrar códigodel ejemplo: Valor
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Esto es un label"
},
"id": "value",
"name": "valor",
"value": "Esto es un valor"
}) }}
HTML
<!-- input --><divclass="c-form-group"><!-- label --><labelclass="block"for="value">Esto es un label</label><!-- /label --><inputclass="c-input block mt-sm border-black rounded-sm font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base"id="value"name="valor"type="text"value="Esto es un valor"></div><!-- /input -->
El atributo placeholder proporciona un texto de ejemplo que se muestra en el campo de entrada cuando está vacío. Intenta usar la pista con el atributo hint en su lugar ya que es más accesible. El placeholder debe ser un apoyo a la pista, no un sustituto.
Descripción visual
Campo de entrada de texto con borde gris de 1px y esquinas redondeadas, fondo blanco. Título en texto negro estándar arriba, seguido de dos líneas de texto en negro. Input muestra texto placeholder en gris claro, tamaño mediano.
Esto es una pista.
Mostrar códigodel ejemplo: Placeholder
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Esto es un label"
},
"hint": {
"text": "Esto es una pista."
},
"id": "con-placeholder",
"name": "placeholder",
"placeholder": "Esto es un placeholder"
}) }}
HTML
<!-- input --><divclass="c-form-group"><!-- label --><labelclass="block"for="con-placeholder">Esto es un label</label><!-- /label --><!-- hint --><pid="con-placeholder-hint"class="block text-neutral-dark">Esto es una pista.</p><!-- /hint --><inputclass="c-input block mt-sm border-black rounded-sm font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base"id="con-placeholder"name="placeholder"type="text"aria-describedby="con-placeholder-hint"placeholder="Esto es un placeholder"></div><!-- /input -->
Campo de entrada de texto con borde gris de 1px y esquinas redondeadas, fondo blanco vacío. Título en texto negro estándar arriba, seguido de label en negro. Input de tamaño mediano sin contenido visible ni placeholder.
Campo de entrada de texto rectangular con borde gris de 1px y fondo blanco. Incluye un label negro en peso normal arriba y texto descriptivo gris claro debajo del label indicando "Este es una pista". Ancho aproximado de 100px, altura estándar de input.
Esto es una pista.
Mostrar códigodel ejemplo: Pista con describedby
Contenido
Nunjucks macro
{%from"components/input/_macro.input.njk" import componentInput %}{{ componentInput({
"label": {
"text": "Pista con describedBy"
},
"hint": {
"text": "Esto es una pista."
},
"id": "with-describedby-b",
"name": "with-describedby-b",
"describedBy": "input-example-a"
}) }}
HTML
<!-- input --><divclass="c-form-group"><!-- label --><labelclass="block"for="with-describedby-b">Pista con describedBy</label><!-- /label --><!-- hint --><pid="with-describedby-b-hint"class="block text-neutral-dark">Esto es una pista.</p><!-- /hint --><inputclass="c-input block mt-sm border-black rounded-sm font-semibold placeholder-neutral-dark focus:border-black focus:shadow-outline-focus-input focus:ring-4 focus:ring-warning-base disabled:bg-neutral-light disabled:border-neutral-base"id="with-describedby-b"name="with-describedby-b"type="text"aria-describedby="input-example-a with-describedby-b-hint"></div><!-- /input -->
Este atributo proporciona información al navegador para que se pueda mostrar el teclado virtual apropiado, especialmente en dispositivos móviles. Este input tiene un inputmode='email'
Descripción visual
Campo de entrada de texto rectangular con borde gris de 1px y fondo blanco. Presenta un label negro en peso normal posicionado arriba del campo. Ancho aproximado de 100px, altura estándar de input, sin elementos adicionales de ayuda o descripción.