a função que deixa de outra cor caso a altura ou peso do paciente seja invalida não esta funcionando mesmo colocando a função classList.add, e ele não explica isso na aula. o que fazer?
a função que deixa de outra cor caso a altura ou peso do paciente seja invalida não esta funcionando mesmo colocando a função classList.add, e ele não explica isso na aula. o que fazer?
Olá Adilson! Poste o seu código aqui pra gente dar uma olhada.
form.js
var botaoAdicionar = document.querySelector("#adicionar-paciente");
botaoAdicionar.addEventListener("click", function(event){
//a função event controla os eventos das paginas e objetos, ela precisa ser passada como parametro igual na linha de cima
//quando é usado o event.preventDefault(); impede que ocorra um evento padrão do objeto como por exemplo recarregar apagina apos clicar
//no enviar de um formulario. podendo dizer qual evento voce quer que ocorra após.
event.preventDefault();
//console.log("cliquei no botão");
//ao selecionar um formulario voce pode ter acesso aos iputs atravez dos name.
var form = document.querySelector("#form-adiciona");
/* foi exugado para a função abaixo
var peso = form.peso.value;//ao contrario dos objetos para selecionar o conteudo de um input usa-se o VALUE não textContent
var altura = form.altura.value;
var gordura = form.gordura.value;
var nome = form.nome.value;
*/
var paciente = obtemPacienteDoFormulario(form);
console.log(paciente);
//a função createElement("") cria um tag dentro do document html mas tem que ser colocada em uma variavel para depois ser exibida
var pacienteTr = document.createElement("tr");
pacienteTr.classList.add("paciente");
var pesoTd = document.createElement("td");
var alturaTd = document.createElement("td");
var gorduraTd = document.createElement("td");
var nomeTd = document.createElement("td");
var imcTd = document.createElement("td");
//nessa parte como não é mais formulario usa o textContent
nomeTd.textContent = nome;
pesoTd.textContent = peso;
alturaTd.textContent = altura;
gorduraTd.textContent = gordura;
imcTd.textContent = calculaImc(altura,peso);
//a função appendChild serve para colocar como filho ou seja colocar dentro da outra tag assim como o td fica dentro do tr
pacienteTr.appendChild(nomeTd);
pacienteTr.appendChild(pesoTd);
pacienteTr.appendChild(alturaTd);
pacienteTr.appendChild(gorduraTd);
pacienteTr.appendChild(imcTd);
var tabela = document.querySelector("#tabela-pacientes");
tabela.appendChild(pacienteTr);
console.log(pacienteTr);
});
function obtemPacienteDoFormulario(form){
//assim se declara um objeto
//para separar as caracteristicas é por meio de : e , no final não tem nada
var paciente = {
nome: form.nome.value,
peso: form.peso.value,
altura: form.altura.value,
gordura: form.gordura.value,
imc: calculaImc(form.altura.value, form.peso.value)
}
return paciente;
}
calcula-imc.js
var titulo = document.querySelector(".titulo");
titulo.textContent = "Nutricionista";
//console.log mostra o conteudo no console
//querySelectorAll == pega todos os conteudos que possuem uma mesma classe
var pacientes = document.querySelectorAll(".paciente");
//var paciente = document.querySelector("#primeiro-paciente");//pegando dados do paciente
//LOOP para verificar todos os pacientes
//length pega o tamanho do array
for(var i = 0 ; i < pacientes.length ; i++){
var paciente = pacientes[i];
var tdPeso = paciente.querySelector(".info-peso");//pegando dados da var paciente que trouxe a tabela
var peso = tdPeso.textContent; //extraindo texto de dentro da tags
//mesmo processo para a altura
var tdAltura = paciente.querySelector(".info-altura");
var altura = tdAltura.textContent;
//console.log(imc);
var tdImc = paciente.querySelector(".info-imc");
//validações || = OR && = AND
var pesoEhValido = true;
var alturaEhValido = true;
if(peso <= 0 || peso >= 300){
//console.log("peso invalido");
pesoEhValido = false;
tdImc.textContent = "Peso Invalido";
paciente.classList.add("paciente-invalido");
}
if(altura <= 0 || altura > 3.00){
//console.log("Altura Invalida");
alturaEhValido = false;
tdImc.textContent = "Altura Invalida";
//classList é uma função que traz a lista de classes de um objeto(nesse caso o paciente) e com o add é possivel
//adicionar uma nova classe sem ir no html e da para alterar direto no css
//OBS não precisa por ponto pois ele ja sabe que é uma classe
paciente.classList.add("paciente-invalido");
}
if(alturaEhValido == true && pesoEhValido == true){
//trocando o imc
var imc = calculaImc(altura,peso);
tdImc.textContent = imc;
}
}//fim for
//função nomeada
function calculaImc(altura,peso){
//calculando o imc == peso/ altura*altura
var imc = 0;
imc = peso / (altura * altura);
return imc.toFixed(2);
};
index.html
<!DOCTYPE html>
<html lang="pt-br">
<head>
<meta charset="UTF-8">
<title>Aparecida Nutrição</title>
<link rel="icon" href="favicon.ico" type="image/x-icon">
<link rel="stylesheet" type="text/css" href="css/reset.css">
<link rel="stylesheet" type="text/css" href="css/index.css">
</head>
<body>
<header>
<div class="container">
<h1 class="titulo">Aparecida Nutrição</h1>
</div>
</header>
<main>
<section class="container">
<h2>Meus pacientes</h2>
<table>
<thead>
<tr>
<th>Nome</th>
<th>Peso(kg)</th>
<th>Altura(m)</th>
<th>Gordura Corporal(%)</th>
<th>IMC</th>
</tr>
</thead>
<tbody id="tabela-pacientes" >
<tr class="paciente" id="primeiro-paciente">
<td class="info-nome">Paulo</td>
<td class="info-peso">1000</td>
<td class="info-altura">22.00</td>
<td class="info-gordura">10</td>
<td class="info-imc">0</td>
</tr>
<tr class="paciente" >
<td class="info-nome">João</td>
<td class="info-peso">80</td>
<td class="info-altura">1.72</td>
<td class="info-gordura">40</td>
<td class="info-imc">0</td>
</tr>
<tr class="paciente" >
<td class="info-nome">Erica</td>
<td class="info-peso">54</td>
<td class="info-altura">1.64</td>
<td class="info-gordura">14</td>
<td class="info-imc">0</td>
</tr>
<tr class="paciente">
<td class="info-nome">Douglas</td>
<td class="info-peso">85</td>
<td class="info-altura">1.73</td>
<td class="info-gordura">24</td>
<td class="info-imc">0</td>
</tr>
<tr class="paciente" >
<td class="info-nome">Tatiana</td>
<td class="info-peso">46</td>
<td class="info-altura">1.55</td>
<td class="info-gordura">19</td>
<td class="info-imc">0</td>
</tr>
</tbody>
</table>
</section>
<section class="container">
<h2 id="titulo-form">Adicionar novo paciente</h2>
<form id="form-adiciona">
<div class="grupo">
<label for="nome">Nome:</label>
<input id="nome" name="nome" type="text" placeholder="digite o nome do seu paciente" class="campo">
</div>
<div class="grupo">
<label for="peso">Peso:</label>
<input id="peso" name="peso" type="text" placeholder="digite o peso do seu paciente" class="campo campo-medio">
</div>
<div class="grupo">
<label for="altura">Altura:</label>
<input id="altura" name="altura" type="text" placeholder="digite a altura do seu paciente" class="campo campo-medio">
</div>
<div class="grupo">
<label for="gordura">% de Gordura:</label>
<input id="gordura" type="text" placeholder="digite a porcentagem de gordura do seu paciente" class="campo campo-medio">
</div>
<button id="adicionar-paciente" class="botao bto-principal">Adicionar</button>
</form>
</section>
</main>
<script src="js/calcula-imc.js"></script>
<script src="js/form.js"></script>
</body>
</html>
Coloca o index.css também.
index.css
*{
box-sizing: border-box;
}
body{
font-family: "Helvetica Neue", "Helvetica", Helvetica, Arial, sans-serif;
font-size: 14px;
}
header{
background-color: #333;
height: 3em;
color: #FFF;
margin-bottom: 1em;
}
header h1{
font-size: 2em;
display:inline-block;
vertical-align: middle;
}
header h2{
font-size: 2em;
display:inline-block;
vertical-align: middle;
}
header .container:before{
content: '';
display:inline-block;
height: 100%;
vertical-align: middle;
}
.container{
width: 60%;
height: 100%;
margin: 0 auto;
}
section{
margin: 2em 0;
overflow: hidden;
}
section h2{
font-size: 3em;
display: block;
padding-bottom: .5em;
border-bottom: 1px solid #ccc;
margin-bottom: .5em;
}
table{
width: 100%;
margin-bottom : .5em;
table-layout: fixed;
}
td, th {
padding: .7em;
margin: 0;
border: 1px solid #ccc;
text-align: center;
}
th{
font-weight: bold;
background-color: #EEE;
}
label{
color: #555;
display: block;
margin-bottom: .2em;
}
.campo{
margin: 0;
padding-bottom: 1em;
width: 100%;
border: 1px solid #ccc;
padding: .7em;
width: 100%;
}
.campo-medio{
display: inline-block;
padding-right: .5em;
}
.grupo{
width: 32%;
display: inline-block;
padding: 10px 0px;
}
button{
padding: .5em 2em;
border: 0;
border-bottom: 3px solid;
font-size: 1.2em;
cursor: pointer;
margin: 0;
margin-top: -3px;
color: #fff;
background-color:#0c8cd3;
border-color: #04324c;
width: 20%;
display: block;
clear: both;
margin: 10px 0px;
}
button:active{
margin-top:0px;
border: 0;
}
button[disabled=disabled], button:disabled {
background-color: gray;
border-color: darkgray;
}
.adicionar-paciente{
margin-top: 30px;
}
.campo-invalido{
border: 1px solid red;
}
.paciente-invalido{
background-color:lightcoral;
}
então o que esta errado?