Olá, boa noite!
Minha dúvida é referente a aula 5 melhorar o código. Antes meu IMC calculava depois que alterei ele de dentro e fiz uma função ele não calcula mais.
Na minha opinião amadora ele não está conseguindo encontrar o peso e altura para realizar o código pois ambas variáveis estão dentro da função addEventListener, mas o professor conseguiu, onde estou errando?
Código JavaScript para calcular o IMC:
var pacientes = document.querySelectorAll(".paciente");
for(var i = 0; i < pacientes.length; i++){
var paciente = pacientes[i];
var peso = paciente.querySelector(".info-peso");
tdPeso = peso.textContent;
var altura = paciente.querySelector(".info-altura");
tdAltura = altura.textContent;
var infoImc = paciente.querySelector(".info-imc");
pesoEhValido = true;
alturaEhValida = true;
if(tdPeso >= 1000 || tdPeso <= 0) {
pesoEhValido = false;
infoImc.textContent = "Peso Inválido"
paciente.classList.add("paciente-invalido");
}
if(tdAltura >= 5.00 || tdAltura <= 0) {
alturaEhValida = false;
infoImc.textContent = "Altura Inválida"
paciente.classList.add("paciente-invalido");
}
if(pesoEhValido && alturaEhValida) {
infoImc.textContent = calculaImc();
}
}
function calculaImc(peso, altura) {
var imc = 0
imc = peso / (altura*altura);
return imc.toFixed(2);
}
E código do formulário:
var botao = document.querySelector("#adicionar-paciente");
botao.addEventListener("click", function(event) {
event.preventDefault();
var form = document.querySelector("#form-adiciona");
var nome = form.nome.value;
var peso = form.peso.value;
var altura = form.altura.value;
var gordura = form.gordura.value;
var pacienteTr = document.createElement("tr");
var nomeTd = document.createElement("td");
var pesoTd = document.createElement("td");
var alturaTd = document.createElement("td");
var gorduraTd = document.createElement("td");
var imcTd = document.createElement("td");
nomeTd.textContent = nome;
pesoTd.textContent = peso;
alturaTd.textContent = altura;
gorduraTd.textContent = gordura;
imcTd.textContent = calculaImc(peso, altura);
pacienteTr.appendChild(nomeTd);
pacienteTr.appendChild(pesoTd);
pacienteTr.appendChild(alturaTd);
pacienteTr.appendChild(gorduraTd);
pacienteTr.appendChild(imcTd);
var tabela = document.querySelector("#tabela-pacientes");
tabela.appendChild(pacienteTr);
})
Obrigado antecipadamente pelo retorno.