Jump to content
huntressDc

Ajuda com atividade Javascript - Calcular troco e exibir notas disponíveis

Recommended Posts

Estou com uma atividade de aula para fazer e gostaria de uma ajuda, devo receber do usuário o valor da compra e o valor pago, e então exibir o troco. Até aí ok, só que também pede para exibir numa textarea as notas utilizadas no troco, informando sempre o mínimo de notas possíveis, exemplo:

 

 

vlrCompra = 53,00
vlrPago = 100,00
vlrTroco = 47,00 

notasTroco = 
4 notas de 10,00
1 nota   de  5,00
2 notas  de  1,00

 

Não sei como fazer essa última parte, alguém para me ajudar? AS NOTAS QUE EU TENHO DISPONIVEIS SAO 1, 5, 10, 50

Eis o que fiz até agora:

 

function calculaTroco(){
    
    var valorCompra = parseFloat($("#valorCompra").val());
    var valorPago = parseFloat($("#valorPago").val());
    var valorTroco = 0;
    
    if (validarCampos() && validarNan()){
        if (valorPago == valorCompra){
            valorTroco = 0;
            $("#valorTroco").val(valorTroco);
            alert("Não gerou troco");
            
        }else if(valorPago > valorCompra){
            
            valorTroco = valorPago - valorCompra;
            $("#valorTroco").val(valorTroco);
            
        }else{
            alert("Não gerou troco (Valor pago menor que valor da compra)");
        }
        notasUtilizadas();
        $("#valorCompra").val("");
        $("#valorPago").val("");
        $("#valorCompra").focus();
    }
}

validarCampos() e validarNan() são apenas funções de tratamento. A função notasUtilizadas() seria a função que não estou conseguindo fazer... Devo utilizar array, if, for nessa atividade.

 

Se alguém puder me ajudar, me dar umas dicas, agradeço muito!

 

Parte do HTML:

<!DOCTYPE html>
<html lang="pt-BR">
    <head>
        <meta charset="utf-8"/>
        <title>Calcular Troco</title>
        <script type="text/javascript" src="jquery.js"></script>
        <style type="text/css">
            fieldset { width:250px; }
            label { display:block; float:left; } 
            label, input, textarea, select { width:150px; margin: 5px 0; }
            th, td { border:1px solid #ccc; font-size:0.9em; }
        </style>
    </head>
    <body>
        
        <form id="formulario">
            <fieldset>
                <legend>Calcular Troco</legend>
                
                <label for="valorCompra" >Valor da compra:</label>
                <input type="text" id="valorCompra" name="valorCompra" /><br />
                
                <label for="valorPago" >Valor pago:</label>
                <input type="text" id="valorPago" name="valorPago" /><br /><br />
                
                <button type="button" id="button" onclick="calculaTroco()">Calcular troco</button><br /><br />
                
                <label for="valorTroco" >Valor do troco:</label>
                <input type="text" id="valorTroco" name="valorTroco" readonly="readonly"/><br /><br />    
                
                <label for="notasUtilizadas">Notas utilizadas:</label>
                <textarea rows="3" id="notasUtilizadas" readonly="readonly" ></textarea><br/>
                
            </fieldset>
        </form>
    <script type="text/javascript" src="troco.js"></script>
    </body>

</html>

Share this post


Link to post
Share on other sites

 Passei os valores como inteiro

 

int ValorCompra = 23, ValorPago = 100, ValorTroco, Nota1, Nota5, Nota10, Nota50;
        String Texto = "Notas à devolver:";
        ValorTroco = ValorPago - ValorCompra;
        Nota50 = ValorTroco / 50;
        ValorTroco = ValorTroco - Nota50 * 50;
        Nota10 = ValorTroco / 10;
        ValorTroco = ValorTroco - Nota10 * 10;
        Nota5 = ValorTroco / 5;
        ValorTroco = ValorTroco - Nota5 * 5;
        Nota1 = ValorTroco / 1;

//agora é so pegar o valor e destribuir do jeito que achar mais facil        

 

 

if (Nota50 > 0) {
            if (Nota50 > 1) {
                Texto = Texto + " " + Nota50 + " Notas de 50 Reais;";
            } else {
                Texto = Texto + " " + Nota50 + " Nota de 50 Reais;";
            }
        }
        if (Nota10 > 0) {
            if (Nota10 > 1) {
                Texto = Texto + " " + Nota10 + " Notas de 10 Reais;";
            } else {
                Texto = Texto + " " + Nota10 + " Nota de 10 Reais;";
            }
        }
        if (Nota5 > 0) {
            if (Nota5 > 1) {
                Texto = Texto + " " + Nota5 + " Notas de 50 Reais;";
            } else {
                Texto = Texto + " " + Nota5 + " Nota de 5 Reais;";
            }
        }
        if (Nota1 > 0) {
            if (Nota1 > 1) {
                Texto = Texto + " " + Nota1 + " Notas de 1 Real;";
            } else {
                Texto = Texto + " " + Nota1 + " Nota de 1 Real;";
            }
        }

        System.out.println("Seu troco é de "+(ValorPago - ValorCompra)+" Reais");
        System.out.println(Texto);

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Juan Carlos PT
      Olá, eu quero poder pegar um vídeo do meu canal na Nimo TV e deixar ele em sites parceiros para fortalecer a minha divulgação. Só que não consigo capturar o código <video></video> do html5 do site na Nimo TV. Eles não mostram o formato do vídeo:
       

      Se alguém souber me ajudar, terei enorme gratidão!
       
      OBS: Perdão se alguém postou algo parecido aqui no site, não vi!

    • By Roberto S. Santos
      Bom dia.
      Eu gostaria de postar uma foto do meu computador no facebok usando VB.NET com login automático.
      Teria como fazer em VB.net ou HTML ?
      Obrigado.
    • By daviassumpcao
      Pessoal... há valores em um JSON sendo exibidos por um JS (imagem anexo)... preciso verificar se um valor "x" está em um determinado nó do JSON. E a partir daí exibir uma div.... marquei na imagem com um círculo rosa qual valor quero verificar porém meu script não funciona... material de estudo. É possível fazer isso acontecer?
       
      JS
      const jsonCat = vtxctx.categoryId; const catProd = JSON.parse(jsonCat); var divProd = document.getElementById('faq-connect'); if (catProd.categoryId == 10103) { divProd.style.display = 'block'; } else{ divProd.style.display = 'none'; } HTML para exibir uma DIV em caso positivo
      <div class="faq-connect" style="display:none"> <p>Sucesso!</p> </div>  
       

    • By paulinhosupriano
      Bom dia a todos!
       
      Gente, tenho uma dúvida!
       
      Muitos desenvolvedores utilizam o framework nodejs com express para trabalhar com API e também estão utilizando o ADONISJS.
      Minha duvida seria, em alguns projetos devemos criar configurações onde o usuário cliente não poderá ter acesso a visualização dos dados public de constantes de configuração, url ou banco. 
      Como protejo essas informações?
      Muitas dizem que seria o arquivo .env. 
       
      Como protegerei essas informações? 
      Exemplo firabase como proteger os dados token etc.
       
      Poderiam informar tutorial, curso, vídeo algo a respeito do assunto? 
       
      Agradecido!
       
    • By violin101
      Caros amigos, saudações...
       
      Estou com uma dúvida de dados vindo do MySql, para preencher Tabela via AJAX.
       
      Como faço para formatar o CAMPO no formato MOEDA, ou seja:
      o campo vem.: 12.00
      formatar para: 12,00
       
      o código está assim:
      function montaTable(cep){ $.ajax({ url: "<?php echo base_url();?>site/produtos/getByCep", type: "POST", dataType:"json", data:{ cep: cep}, success:function(data){ //Remove Mensagem da Tabela $("#tborden tbody tr.message").remove(); var cols = ""; for (var i = 0; i < data.length; i++) { cols += "<tr>"; cols += "<td>" + data[i].cepRegiao + "</td>"; cols += "<td>" + data[i].frtEntreg + "</td>"; cols += "<td>" + data[i].vlrFrete + "</td>"; //<--como formatar esse campo cols += "</tr>"; } //Atualiza a Tabela $("#tborden tbody").empty(); //Adiciona os Itens a Tabela $("#tborden tbody").append(cols); } });//Fim - ajax Valor Frete }

      Grato,
       
      Cesar
×

Important Information

Ao usar o fórum, você concorda com nossos Terms of Use.