Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/waldohidalgo/proyecto_practico_js-en-la-web-validacion-de-formularios-y-html5
Proyecto practico del curso JS en la Web: Validación de Formularios y HTML5 en el cual realizo lo que hace el instructor para practicar lo enseñado
https://github.com/waldohidalgo/proyecto_practico_js-en-la-web-validacion-de-formularios-y-html5
oraclenexteducation
Last synced: 26 days ago
JSON representation
Proyecto practico del curso JS en la Web: Validación de Formularios y HTML5 en el cual realizo lo que hace el instructor para practicar lo enseñado
- Host: GitHub
- URL: https://github.com/waldohidalgo/proyecto_practico_js-en-la-web-validacion-de-formularios-y-html5
- Owner: waldohidalgo
- Created: 2023-07-08T00:53:58.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-07-08T15:49:18.000Z (over 1 year ago)
- Last Synced: 2023-09-10T18:47:43.870Z (over 1 year ago)
- Topics: oraclenexteducation
- Language: CSS
- Homepage: https://waldo-analista.github.io/proyecto_practico_JS-en-la-Web-Validacion-de-Formularios-y-HTML5/
- Size: 17.6 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
### Proyecto practico del curso llamado "JS en la Web: Validación de Formularios y HTML5". Se practica lo siguiente:
-Hacer validaciones en el propio HTML (sin javascript) usando atributos tales como required y type con el valor email, por ejemplo.
-Se puede utilizar el atributo pattern con una expresion regular para validar campos. Se crea la expresion regular ```^(!?#\$%&\/\(\)\[\]\?¡)(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9]).{6,12}$``` para validar el campo contraseña la cual debe tener al menos 1 número, al menos una letra minúscula, al menos una letra mayúscula, no contener ninguno de los caracteres especiales siguientes: ?,!,#,$,%,&,/,(,),[,],?,! y tener una cantidad entre 6 y 12 caracteres. Se escapan algunos caracteres especiales con el símbolo \ para evitar que sean reconocidos como comando y solo sean considerados como caracteres.
-Se muestra un mensaje personalizado de error en el navegador para el input contraseña utilizando el atributo title
-Se muestra un mensaje personalizado de error en el navegador para el campo fecha de nacimiento vía javascript usando el método **setCustomValidity()** del input
-Se hace una mejora del código utilizando data attributes y creando un objeto con el valor del atributo el cual se le asigna una funcion anónima. Posteriormente, se captura el valor del data attribute y se verifica que en el objeto exista esa propiedad. Si existe, se accede a la funcion anónima y se muestra la validación de la edad el cual usa el método setCustomValidity()
-Se agrega o remueve el nombre de una clase cuando el input pierde el focus (evento **blur**)
-Se accede a la propiedad validity de un input el cual **DEBE** tener el atributo required. La propiedad validity retorna un objeto y se accede a la propiedad valid que retorna un booleano indicando si el input es válido o no ( si pasa el criterio de validación)
-Se crea un array de strings con el nombre de las propiedades que arroja el objeto validity. Específicamente, las propiedades son las siguientes: **valueMissing**, **typeMismatch**, **patternMismatch** y **customError**.
-Se crea una función para recorrer el array y para cada elemento del array se verifica si la propiedad es verdadera en el objeto validity, si la propiedad es verdadera, se personaliza el mensaje de error que se muestra en el HTML cuando ocurre el evento blur sobre el input.
-Se crean expresiones regulares para los input: Número Telefónico, Dirección, Ciudad, Estado y se agregan los data attributes para los input que no los poseen de modo que se mostrarán mensajes personalizados para cada input