Cómo crear: verificación de contraseña
- Página anterior Activar el botón con la tecla Enter
- Página siguiente Cambiar la visibilidad de la contraseña
Aprende a crear un formulario de verificación de contraseña utilizando CSS y JavaScript.

Crear un formulario de verificación de contraseña
Paso 1 - Añadir HTML:
<div class="container"> <form action="/action_page.php"> <label for="usrname">Username</label> <input type="text" id="usrname" name="usrname" required> <label for="psw">Contraseña</label> <input type="password" id="psw" name="psw" pattern="(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,}" title="Debe contener al menos un número y una letra mayúscula y minúscula, y al menos 8 o más caracteres" required> <input type="submit" value="Enviar"> </form> </div> <div id="message"> <h3>La contraseña debe contener lo siguiente:</h3> <p id="letter" class="invalid">Una <b>letra minúscula</b></p> <p id="capital" class="invalid">Una <b>letra mayúscula</b></p> <p id="number" class="invalid">Un <b>número</b></p> <p id="length" class="invalid">Mínimo <b>8 caracteres</b></p> </div>
Nota:Usamos la propiedad pattern (con expresión regular) en el campo de contraseña para establecer las restricciones del formulario de envío: debe contener 8 o más caracteres, entre los cuales al menos uno debe ser un número, una letra mayúscula y una letra minúscula.
Segundo paso - Añadir CSS:
Establecer el estilo de los campos de entrada y cuadros de mensaje:
/* Establecer el estilo de todos los campos de entrada */ input { width: 100%; padding: 12px; border: 1px solid #ccc; border-radius: 4px; box-sizing: border-box; margin-top: 6px; margin-bottom: 16px; } /* Establecer el estilo del botón de envío */ input[type=submit] { background-color: #04AA6D; color: white; } /* Establecer el estilo del contenedor de entrada */ .container { background-color: #f1f1f1; padding: 20px; } /* Al hacer clic en el campo de contraseña, mostrar el cuadro de mensaje */ #message { display:none; background: #f1f1f1; color: #000; position: relative; padding: 20px; margin-top: 10px; } #message p { padding: 10px 35px; font-size: 18px; } /* Al requerir que sea correcto, agregar color de texto verde y marca de verificación. */ .valid { color: green; } .valid:before { position: relative; left: -35px; content: "✔"; } /* Al requerir un error, agregar color de texto rojo y un icono "x". */ .invalid { color: red; } .invalid:before { position: relative; left: -35px; content: "✖"; }
Tercero - Añadir JavaScript:
<script> var myInput = document.getElementById("psw"); var letter = document.getElementById("letter"); var capital = document.getElementById("capital"); var number = document.getElementById("number"); var length = document.getElementById("length"); // Al hacer clic en el campo de contraseña, mostrar el cuadro de mensaje myInput.onfocus = function() { document.getElementById("message").style.display = "block"; } // Al hacer clic fuera del campo de contraseña, ocultar el cuadro de mensaje myInput.onblur = function() { document.getElementById("message").style.display = "none"; } // Cuando el usuario comienza a escribir contenido en el campo de contraseña myInput.onkeyup = function() { // Validar letras minúsculas var lowerCaseLetters = /[a-z]/g; if(myInput.value.match(lowerCaseLetters)) { letter.classList.remove("invalid"); letter.classList.add("valid"); } else { letter.classList.remove("valid"); letter.classList.add("invalid"); } // Verificar letras mayúsculas var upperCaseLetters = /[A-Z]/g; if(myInput.value.match(upperCaseLetters)) { capital.classList.remove("invalid"); capital.classList.add("valid"); } else { capital.classList.remove("valid"); capital.classList.add("invalid"); } // Verificar números var numbers = /[0-9]/g; if(myInput.value.match(numbers)) { number.classList.remove("invalid"); number.classList.add("valid"); } else { number.classList.remove("valid"); number.classList.add("invalid"); } // Verificar longitud if(myInput.value.length >= 8) { length.classList.remove("invalid"); length.classList.add("valid"); } else { length.classList.remove("valid"); length.classList.add("invalid"); } } </script>
Páginas relacionadas
Tutoriales:Formulario HTML
- Página anterior Activar el botón con la tecla Enter
- Página siguiente Cambiar la visibilidad de la contraseña