Ir para conteúdo

POWERED BY:

Arquivado

Este tópico foi arquivado e está fechado para novas respostas.

BrazucaBostero

Porcentagem com JavaScript

Recommended Posts

Olá!

 

Estou com uma dúvida daquelas sobre um código de calculo de desconto no javascript, abaixo segue o código

 

JS

        function calcValor() {
        //Declarando as variaveis  
         let preco, porcentagem, desconto, novopreco;
        //Obtendo dados atraves do prompt
        preco = parseFloat(document.getElementById("CAMPO_87").value);
        porcentagem = parseFloat(document.getElementById("CAMPO_85").value);
        alert(preco)
        document.getElementById("CAMPO_88").value = preco;
        alert(preco)
        //Realizando os calculos
        desconto = preco * porcentagem / 100;
        novopreco = preco - desconto;
        //O .toFixed(2) faz com que o valor seja corrijdo para duas casas decimais
        document.getElementById("CAMPO_88").value = novopreco;
        }

HTML

                        <div class="row">
                            <div class="col-md-2"><label class="a3label control-label" for="CAMPO_87">Valor da Mensalidade</label> <input class="a3formcontrol form-control" data-campo-id="@@87@@" data-nome="87 - Valor Mensalidade" data-tipo-documental-id="3" id="CAMPO_87"
                                    oninput="calcValor()" type="text" />
                            </div>

                            <div class="col-md-2"><label class="a3label control-label" for="CAMPO_85">Bolsa (%)</label> <input class="a3formcontrol form-control" data-campo-id="@@85@@" data-nome="85 - Bolsa (%)" data-tipo-documental-id="3" id="CAMPO_85" oninput="calcValor()"
                                    type="text" /></div>
                        </div>

                        <div class="row">
                            <div class="col-md-2"><label class="a3label control-label" for="CAMPO_88">Mensalidade Final</label> <input class="a3formcontrol form-control" data-campo-id="@@88@@" data-nome="88 - Valor Mensalidade (F)" data-tipo-documental-id="3" id="CAMPO_88"
                                    type="text" oninput="calcValor()" /></div>

 

 

O que acontece, tenho 2 problemas, que estou a quase 1 semana e não consigo resolver

 

 

Quando jogo somente o valor do campo mensalidade, ele deveria teoricamente aparecer no campo mensalidade final, independente ou não de haver desconto, porém para minha surpresa ele aparece exatamente igual a imagem abaixo

 

Capturar.PNG.eadbb10161ba58c2e5ae296441d0a19c.PNG

 

 

E minha outra dúvida é sobre a questão de , e .

Quando calculo desconto com , por exemplo. 2314,50, ele arredonda e quando coloco 2314.50, ele me da o valor exato. Alguém pode me dar uma luz? Desde já fico agredecido

Compartilhar este post


Link para o post
Compartilhar em outros sites

Simples erro clássico de programação sem validação de valores em cálculos.

1-zero não é divisível da mesma forma que null também não

2-comma é ignorada em cálculos você deve realizar um replace.

 

Obs: como você descreveu que o valor deveria aparecer independente do valor informado, você deve ter em mente que o erro ocorre mostrando NaN, pq a variável desconto está na formula toda iteração então e seu trabalho cuidar pra que ela tenha um valor default ou seja inicializada pra evitar isso já que está trabalhando com cálculos. 

 

solução:

function calcValor() {
  //Declarando as variaveis  
  let preco, porcentagem, desconto, novopreco;
  
  //Obtendo dados atraves do prompt
  preco = document.getElementById("CAMPO_87").value.replace(',','.');
  preco = parseFloat(preco);
  porcentagem = parseFloat(document.getElementById("CAMPO_85").value || 0);
  
  console.log(preco)
  
  document.getElementById("CAMPO_88").value = preco;
  
  console.log(preco)
  
  //Realizando os calculos
  desconto = preco * porcentagem / 100;
  novopreco = preco - desconto;
  
  //O .toFixed(2) faz com que o valor seja corrijdo para duas casas decimais
  document.getElementById("CAMPO_88").value = novopreco || "";
}

 

Sugestão de refactor

function calcValor() {
  //Declarando as variaveis  
  let preco, porcentagem, desconto, novopreco;
  
  //Obtendo dados
  preco = getPreco();
  porcentagem = getPorcentagem();
  
  //Set dados
  if(porcentagem){
    novopreco = calculoPorcentagem(preco, porcentagem);
    setMensalidadeField(novopreco);
  } else {
    setMensalidadeField(preco);
  }
}

function getPreco() {
  return parseFloat(document.getElementById("CAMPO_87").value.replace(',','.'));
}

function getPorcentagem() {
  return porcentagem = parseFloat(document.getElementById("CAMPO_85").value || 0);
}

function calculoPorcentagem(preco, porcentagem) {
  const desconto = preco * porcentagem / 100;
  return preco - desconto;
}

function setMensalidadeField(preco) {
  document.getElementById("CAMPO_88").value = preco;
}

 

jsbin: https://jsbin.com/yalokuyinu/edit?html,js,output

 

 

Compartilhar este post


Link para o post
Compartilhar em outros sites

  • Conteúdo Similar

    • Por ILR master
      No código abaixo, funciona perfeitamente quando chamo: dominio.com.br/noticia/todas
       
      <?php
          $url = (isset($_GET['url'])) ? $_GET['url'] : 'principal';
          $url = array_filter(explode('/', $url));
          //var_dump($url);
          $file = $url[0] . '.php';
          if (is_file($file)) {
              include $file;
          } else {
              include '404.php';
          }
          ?>
       
      Porém, quero usar variáveis com ? e &, tipo: dominio.com.br/busca/?campo=assunto
       
      Como faço pra conseguir isso?
       
      Valeu!!!
    • Por ILR master
      Fala pessoal, tudo na boa?
      Eu uso o wamp para desenvolver e testas meu site antes de jogar no servidor.
      A dúvida é o seguinte:
       
      No servidor, eu consigo ler as variáveis numa boa, mas no localhost não. Meu código no index está assim:
       
      $atual = (isset($_GET['pg'])) ? $_GET['pg'] : 'principal';
      $permissao = array('principal','contribua','quem-somos','politica-de-privacidade','termos-de-uso','evento','busca','galeria','galerias','clickbanner','noticia','noticias','contato','video');
      if(substr_count($atual, '/') > 0){
          $atual = explode('/', $atual);
          $pagina = (file_exists($atual[0]. '.php') && in_array($atual[0], $permissao)) ? $atual[0] : 'erro';
          $pg1 = $atual[1];
          $pg2 = $atual[2];
          $pg3 = $atual[3];
          $urltitulo = $atual[3];
      }else{
          $pagina = (file_exists($atual. '.php') && in_array($atual, $permissao)) ? $atual : 'erro';
          $codigo =0;
      };
       
      No servidor, quando chamo: dominio.com.br/pagina/variavel
      ele já identifica as variáveis  $pg1 = $atual[1]; e $pg2 = $atual[2];
      print $pg1 = pagina
      print $pg2 = variavel
      Ele me tras os resultados 

      No localhost não. Ele não reconhece as variáveis

      Alguém sabe como arrumo isso no wamp?
       
      At,
    • Por luiz monteiro
      Olá.
      Estou atualizando meu conhecimento com Front-End e me deparei com o seguinte problema.
      Criei um sistema para fazer o upload de imagens e alguns campos text.
      Algo bem simples para depois começar a estudar javascript para mostrar a miniatura....
      Mas quando saio do navegador Chrome ou da aba por mais de 3 minutos, ao retornar o navegador as vezes atualiza ou nem chega atualizar mas limpa os campos.
      Estou usando um Smart Motorola com Android, mas um amigo testou no iPhone e acontece a mesma coisa.
      Gostaria de saber se há como usar javascript para evitar isso?
      Agradeço desde já.

      <!DOCTYPE html>
      <html>
      <head>
          <meta charset="utf-8">
          <meta name="viewport" content="width=device-width, initial-scale=1">
          <title>Uploader</title>
      </head>
      <body>
          <form action="?" method="post" enctype="multipart/form-data">
              <br><br>
              <div>selecione a imagem 1</div>
              <input type="file" name="foto1" accept="image/*">
              <br><br>
              <input type="text" name="nome_imagem1">
              
              <br><br>
              <input type="file" name="foto2" accept="image/*">
              <br><br>
              <input type="text" name="nome_imagem2">
              
              <br><br>

              <input type="file" name="foto3" accept="image/*">
              <br><br>
              <input type="text" name="nome_imagem3">
              
              <br><br>
              <input type="submit" value="Enviar">
              <br><br>
          </form>
      <?php
      if ($_SERVER['REQUEST_METHOD'] == 'POST')
      {
          vardump ($_FILES);
      }
      ?>
      </body>
      </html>
       
       
       
    • Por belann
      Olá!
       
      Estou usando o nextjs versão 15.2.3 e criei uma navbar que quando é carregado o programa aparece com a home, mas na hora de clicar na página produtos desaparece a navbar.
      A navbar esta sendo chamada no layout.tsx estou usando typescript
      e fica dessa forma
      <div>           <Navbar/>             <main>{children}</main>             </div>  
    • Por violin101
      Caros amigos, saudações.

      Estou com uma dúvida, referente cálculo de valores em tempo real.

      Tenho uma rotina, que faz o cálculo, o problema é mostrar o resultado.

      Quero mostrar o RESULTADO assim: 0,00  ou  0.00

      Abaixo posto o código.
      jQuery('input').on('keyup',function(){ //Remover ponto e trocar a virgula por ponto var m = document.getElementById("pgRest").value; while (m.indexOf(".") >= 0) { m = m.replace(".", ""); } m = m.replace(",","."); //Remover ponto e trocar a virgula por ponto var j = document.getElementById("pgDsct").value; while (j.indexOf(".") >= 0) { j = j.replace(".", ""); } j = j.replace(",","."); m = parseFloat(jQuery('#pgRest').val() != '' ? jQuery('#pgRest').val() : 0); j = parseFloat(jQuery('#pgDsct').val() != '' ? jQuery('#pgDsct').val() : 0); //Mostra o Resultado em Tempo Real jQuery('#pgTroco').val(m - j); <<=== aqui estou errando })  
       
      Grato,
       
      Cesar
       
       
×

Informação importante

Ao usar o fórum, você concorda com nossos Termos e condições.