Segue meu código em validacao.js
export function valida(input) {
const tipoDeInput = input.dataset.tipo
if(validadores[tipoDeInput]) {
validadores[tipoDeInput](input)
}
}
const validadores = {
dataNascimento:input => validaDataNascimento(input)
}
function validaDataNascimento(input) {
const dataRecebida = new Date(input.value);
let mensagem = ''
if(!maiorQue18(dataRecebida)) {
mensagem = 'Você deve ser maior que 18 anos para se cadastrar.'
}
input.setCustomValidity(mensagem);
}
function maiorQue18(data) {
const dataAtual = new Date(); //date() é automaticamente preenchido com a data atual
const dataMais18 = new Date(data.getUTCFullYear() + 18, data.getUTCMonth(), data.getUTCDate());
return dataMais18 <= dataAtual;
}
Código app.js
import { valida } from './validacao.js'
const inputs = document.querySelectorAll('input')
inputs.forEach(input => {
input.addEventListener('blur', (evento) => {
valida(evento.target)
})
})
E sim, eu chamei ambos os scripts no HTML.