Jump to content
Eduardo_555

Transformar Float para padrão de moedas reais (R$)?

Recommended Posts

OLA bom dia , boa tarde, boa noite, boa madrugada...

 

O problema e o seguinte, tenho um valor que entra pela caixa de texto vai até o codigo e calcula, diversas porcentagens sobre ele, depois exibe o valor com desconto.

 

porem fiz isso para exibir os valores em float, isto e com 2 casas depois da virgula.

 

porem agora me solicitaram que os valores fiquem como se fosse dinheiro, ou seja

 

inves de 1000.00

fique assim 1.000,00

 

Esta cheio de idea no google, porem nenhum eu consegui implementar no meu caso, ja que fasso diversos calculos, e sao diversas saidas, se eu repetir um codigo de transformaçao, em cada saida de porcentagem vai ficar muito extenso.

 

oque acham, como fariam.

Este e o codigo.

<DOCTYPE html>
<html lang="pt-br">
<head>
<meta charset="UTF-8">
<link rel="stylesheet" href="style123456789/estiloblocode3.css" type="text/css" media="screen">
<title>SUINO</title>
<script language="javascript">
function disableselect(e){
return false
}
function reEnable(){
return true
}
//if IE4+
document.onselectstart=new Function ("return false")
document.oncontextmenu=new Function ("return false")
//if NS6 
if (window.sidebar){
document.onmousedown=disableselect
dosument.onclick=reEnable
}
</script>
<script type="text/javascript">
window.onload = function(){
 
    var i = function(id){ return document.getElementById(id); }
     
    i("calcula").onclick = function(){
      var valor = i("campo1").value;
     i("total").innerHTML = (parseFloat(valor)).toFixed(2)
i("icms").innerHTML = (parseFloat(valor)*1.0325-parseFloat(valor)).toFixed(2)
i("pis").innerHTML = (parseFloat(valor)*1.01665-parseFloat(valor)).toFixed(2)
i("soma").innerHTML = ((parseFloat(valor)*1.0325-parseFloat(valor))+(parseFloat(valor)*1.01665-parseFloat(valor))).toFixed(2)
 
i("total1").innerHTML = (parseFloat(valor)).toFixed(2)
i("icms1").innerHTML = (parseFloat(valor)*1.0325-parseFloat(valor)).toFixed(2)
i("pis1").innerHTML = (parseFloat(valor)*1.01665-parseFloat(valor)).toFixed(2)
i("soma1").innerHTML = ((parseFloat(valor)*1.0325-parseFloat(valor))+(parseFloat(valor)*1.01665-parseFloat(valor))).toFixed(2)
 
i("total2").innerHTML = (parseFloat(valor)).toFixed(2)
i("icms2").innerHTML = (parseFloat(valor)*1.0325-parseFloat(valor)).toFixed(2)
i("pis2").innerHTML = (parseFloat(valor)*1.01665-parseFloat(valor)).toFixed(2)
i("soma2").innerHTML = ((parseFloat(valor)*1.0325-parseFloat(valor))+(parseFloat(valor)*1.01665-parseFloat(valor))).toFixed(2)
    }
  }  
</script>
</head>
<body class="fadeIn">
<div class="pagina">
 
 
<div class="barra padding">
<div class="titulo">
<h1>SUINO</h1>
</div>
<div class="campo">
<br>
Informe o valor da compra.
<br> 
<br>
 
<input type="text" id="campo1"/>
<button id="calcula">calcular</button>
 
</div>
</div>
<br>
<br>
 
 
<div id="container"> 
 
<div class="tile1 cor">
<br>
       PESOSA FISICA COM FUNRURAL
<br>
<hr align="center" width="300" size="7" color=#9C9C9C>
<br>
  TOTAL DAS COMPRAS:         <span id="total">0,00</span>
<br>
<hr align="center" width="250" size="5" color=#9C9C9C>
<br>
  VALOR ICMS:                      <span id="icms">0,00</span>
<br>
<hr align="center" width="250" size="5" color=#9C9C9C>
<br>
  VALOR DE PIS E CONFINS:     <span id="pis">0,00</span>
<br>
<hr align="center" width="250" size="5" color=#9C9C9C>
<br>
  TOTAL DOS IMPOSTOS:        <span id="soma">0,00</span>
<br>
</div>
 
<div class="tile2 cor">
<br>
       PESSOA FISICA SEM FUNRURAL
<br>
<hr align="center" width="300" size="7" color=#9C9C9C>
<br>
  TOTAL DAS COMPRAS:         <span id="total1">0,00</span>
<br>
<hr align="center" width="250" size="5" color=#9C9C9C>
<br>
  VALOR ICMS:                      <span id="icms1">0,00</span>
<br>
<hr align="center" width="250" size="5" color=#9C9C9C>
<br>
  VALOR DE PIS E CONFINS:     <span id="pis1">0,00</span>
<br>
<hr align="center" width="250" size="5" color=#9C9C9C>
<br>
  TOTAL DOS IMPOSTOS:        <span id="soma1">0,00</span>
<br>
</div>
 
<div class="tile3 cor">
<br>
                     COPERATIVA
<br>
<hr align="center" width="300" size="7" color=#9C9C9C>
<br>
  TOTAL DAS COMPRAS:         <span id="total2">0,00</span>
<br>
<hr align="center" width="250" size="5" color=#9C9C9C>
<br>
  VALOR ICMS:                      <span id="icms2">0,00</span>
<br>
<hr align="center" width="250" size="5" color=#9C9C9C>
<br>
  VALOR DE PIS E CONFINS:     <span id="pis2">0,00</span>
<br>
<hr align="center" width="250" size="5" color=#9C9C9C>
<br>
  TOTAL DOS IMPOSTOS:        <span id="soma2">0,00</span>
<br>
</div>
</div>
</div>
 
 
<span style="position:absolute; top:25; left:150; width:10; height:10;">
<img src="midia/porco.png" width="120px" height="120px"/>
</span>
<span style="position: absolute; top: 580px; left: 110px; width:103px; height:61px">
<a href="menu.html"><img src="midia/retorno.png" width="50px" height="50px"/>
</span>
 
<span style="position: absolute; top: 15px; left: 1257px; width: 100px">
<img src="midia/LL.png" width="100px" height="100px"/>
</span>
 
<div id="referncia">
<h6>© hhhhhhh - v 1.0<h6>
</div>
</body>
</html>
  

Aguardo retorno.

Edited by William Bruno
Adicionar code

Share this post


Link to post
Share on other sites

Olá Eduardo, eu recomendaria você a usar uma mascara para exibir como dinheiro e calcular os valores sem mascara.

Share this post


Link to post
Share on other sites

Olá Eduardo, eu recomendaria você a usar uma mascara para exibir como dinheiro e calcular os valores sem mascara.

 

ola sergio, como assim, na verdade sou bem iniciante m javascript,

 

estou com um pouco de dificuldade neste calculo, oque seria usar uam mascara??

 

e como eu usaria em meu caso, basta adicionar na saida dos dados,

 

ou eles ja podem entrar com mascara e calcular assim como dinheiro mesmo??

 

ajuda ia cara!!!1

Share this post


Link to post
Share on other sites

Fala Eduardo, beleze, segue um exemplo:

<html>
<head>


</head>
<body>

<script language="javascript">

//calcula as moedas
function calcularMoeda(){
var valor1 = document.getElementById("txtValor1").value; //pego o value do textbox1
var valor2 = document.getElementById("txtValor2").value; //pego o value do textbox1

//removo os pontos e virgulas para calcular o valor
valor1 = valor1.replace(".", ""); //removo os pontos
valor1 = valor1.replace(",", ""); //removo as virgulas

valor2 = valor2.replace(".", ""); //removo os pontos
valor2 = valor2.replace(",", ""); //removo as virgulas

valor1 = parseFloat(valor1); //transform em float
valor2 = parseFloat(valor2); //transform em float
var resultado = valor1 + valor2; //calculo as moedas

resultado = MascaraMoedaValue("" + resultado + "",'.',','); //transformo em moeda novamente

alert(resultado);
}

//mascara para numeros completos
function MascaraMoedaValue(valor, SeparadorMilesimo, SeparadorDecimal){
var sep = 0;
var key = '';
var i = j = 0;
var len = len2 = 0;
var strCheck = '0123456789';
var aux = aux2 = '';

if (strCheck.indexOf(key) == -1) return false; // Chave inválida
len = valor.length;
for(i = 0; i < len; i++)
if ((valor.charAt(i) != '0') && (valor.charAt(i) != SeparadorDecimal)) break;
aux = '';
for(; i < len; i++)
if (strCheck.indexOf(valor.charAt(i))!=-1) aux += valor.charAt(i);
len = aux.length;
if (len == 0) valor = '';
if (len == 1) valor = '0'+ SeparadorDecimal + '0' + aux;
if (len == 2) valor = '0'+ SeparadorDecimal + aux;
if (len > 2) {
aux2 = '';
for (j = 0, i = len - 3; i >= 0; i--) {
if (j == 3) {
aux2 += SeparadorMilesimo;
j = 0;
}
aux2 += aux.charAt(i);
j++;
}
valor = '';
len2 = aux2.length;
for (i = len2 - 1; i >= 0; i--)
valor += aux2.charAt(i);
valor += SeparadorDecimal + aux.substr(len - 2, len);

return valor;
}
return false;
}

//mascara para numeros a serem digitados
function MascaraMoedaInput(objTextBox, SeparadorMilesimo, SeparadorDecimal, e){
var sep = 0;
var key = '';
var i = j = 0;
var len = len2 = 0;
var strCheck = '0123456789';
var aux = aux2 = '';
var whichCode = (window.Event) ? e.which : e.keyCode;
if (whichCode == 13) return true;
key = String.fromCharCode(whichCode); // Valor para o código da Chave
if (strCheck.indexOf(key) == -1) return false; // Chave inválida
len = objTextBox.value.length;
for(i = 0; i < len; i++)
if ((objTextBox.value.charAt(i) != '0') && (objTextBox.value.charAt(i) != SeparadorDecimal)) break;
aux = '';
for(; i < len; i++)
if (strCheck.indexOf(objTextBox.value.charAt(i))!=-1) aux += objTextBox.value.charAt(i);
aux += key;
len = aux.length;
if (len == 0) objTextBox.value = '';
if (len == 1) objTextBox.value = '0'+ SeparadorDecimal + '0' + aux;
if (len == 2) objTextBox.value = '0'+ SeparadorDecimal + aux;
if (len > 2) {
aux2 = '';
for (j = 0, i = len - 3; i >= 0; i--) {
if (j == 3) {
aux2 += SeparadorMilesimo;
j = 0;
}
aux2 += aux.charAt(i);
j++;
}
objTextBox.value = '';
len2 = aux2.length;
for (i = len2 - 1; i >= 0; i--)
objTextBox.value += aux2.charAt(i);
objTextBox.value += SeparadorDecimal + aux.substr(len - 2, len);
}
return false;
}
</script>
<form>
Valor 1 R$: <input type="text" name="valor1" id="txtValor1" onKeyPress="return(MascaraMoedaInput(this,'.',',',event))">
Valor 2 R$: <input type="text" name="valor2" id="txtValor2" onKeyPress="return(MascaraMoedaInput(this,'.',',',event))">
<button type="button" onclick="calcularMoeda()">Calcular</button>
</form>


</body>
</html>

Este exemplo transforma os valores e clicando no botao ele calcula. A mascara você pode guardar em algum script separado para seu código não ficar poluido.

  • +1 1

Share this post


Link to post
Share on other sites

Bom dia amigo,

Desculpa de encomodar mas estava precisando de um script javascript que pudesse me ajudar a solicionar um problema básico de conta de subtração com valores em dinheiro, fiz um código mascarado tudo certo e estou em um impasse pois o script quando retiro os pontos e virgulas os calculos com valores baixo como por exemplo 

200 - 100 da um valor muito ato pois o código se confunde apos eu retirar os pontos, valores acima de 1000 funciona perfeitamente.

Pesquisando na internet achei sua explicação que solucione o me problema até perceber que se eu digitar por exemplo 1,75 - 2,00 retorna um valor null, ou valores abaixo me retorna false, como seu código era soma eu só mudei o sinal e mais nada, você poderia me ajudar pq esta dando este retorno, alias eu poderia usar sou código e você me ajudaria este ajunte do valor false.

Alguém poderia me ajudar?

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 Febatera7
      Preciso construir um microsserviço, apenas no lado do servidor (Node.js) que leia menções e comentários em postagens em que o @ do meu cliente foi marcado, em seguida, salve essas mensagens em nosso banco de dados, para especialistas de atendimento para responderem mais tarde.
      Este microsserviço também deve ser capaz de ler e salvar as fotos destas postagens e comentários.
      Para Node.js, vi que não há SDK, então procurei os terceiros que o próprio Facebook indica, mas não encontrei nada sobre ler e responder a menções e comentários em postagens.
      Tentei utilizar as bibliotecas fb e fbgraph, mas nenhuma delas me dá as opções para ler postagens em que fui marcado, apenas as do meu próprio feed.
      Alguém pode me ajudar? Por onde posso começar? Há alguma outra biblioteca que consiga utilizar?
    • By Sapinn
      Fala galera, tudo blz? Então estou com uma dúvida um pouco boba mas que não consegui resolver o problema ainda. Estou desenvolvendo um site para agendamento de serviços e resolvi fazer a pagina principal como uma dashboard (área de administrador) onde seria muito mais fácil para o usuário registrar os serviços entre outras coisas, enfim, estou com um problema quanto ao layout da página. Normalmente o dashboard tem um menu à esquerda e o conteúdo  fica à direita quando ocorre o clique no botão hambúrguer( Aquele que tem três tracinhos) esse menu é recolhido e esse conteúdo que fica a direita fica centralizado, às vezes, em muitos dashboard esse menu só é um pouco recolhido ficando amostra apenas os ícones enquanto o conteúdo da direita fica um pouco mais centralizado. A pergunta é como eu posso fazer isso? Outra coisa, na responsividade quando a página diminui o menu da uma retraída e o conteúdo fica centralizado quando é clicado no botão hambúrguer o menu não afasta o conteúdo de volta e sim fica por cima desse conteúdo. Não sei como fazer isso, eu estou melhorando quando ao desenvolvimento front-end mas ainda não é muito a minha praia. Eu tentei fazer isso com css grid (que por sinal é algo que eu não tenho tanta pratica, já que eu sou melhor com flebox) mas não funcionou e o código só ficou ruim e confuso. Se alguém puder me ajudar ficaria muito grato
       
      Não tem muito coisa ainda mas irei disponibilizar o código que desenvolvi até agora:
       
      <!DOCTYPE html> <html lang="pt-br"> <head>     <meta charset="UTF-8">     <meta http-equiv="X-UA-Compatible" content="IE=edge">     <meta name="viewport" content="width=device-width, initial-scale=1.0">     <title>Sistema de Gerenciamento</title>     <link rel="stylesheet" href="assets/css/style.css">     <link rel="icon" href="assets/images/icone-logo.png">     <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/bootstrap-icons@1.4.1/font/bootstrap-icons.css"> </head> <body>     <header>         <div class="bar-header">             <i class="bi bi-list"></i>         </div>     </header>     <nav class="menu">         <div class="user">             <i class="bi bi-person-circle"></i>             <p>Nome do Usuário</p>         </div>         <ul>             <li class="active"><a href=""><i class="bi bi-house-fill"></i> Inicio</a></li>             <li><a href=""><i class="bi bi-calendar-plus-fill"> </i>Adicionar Serviço</a></li>             <li><a href=""><i class="bi bi-person-plus-fill"></i> Adicionar Admin</a></li>             <li><a href=""><i class="bi bi-file-earmark-post-fill"></i> Configurações de Nota</a></li>             <li><a href=""><i class="bi bi-file-person"></i> Configurações da Conta</a></li>             <li><a href=""><i class="bi bi-box-arrow-right"></i> Sair</a></li>         </ul>     </nav>     <main></main>     <footer></footer> </body> </html>  
       
      *{     padding: 0;     margin: 0; } body{     font-family: Arial, Helvetica, sans-serif;     background-color: #e5e5e5; } .bar-header{     background-color: #4285f4;     position: fixed;     color: #fff;     width: 100%;     height: 40px;     font-size: 37px;     padding: 8px 16px;     z-index: 1; } .menu{     background-color: #26353e;     width: 260px;     height: 100vh;     position: fixed;     padding-top: 65px; } .menu ul li{     list-style: none;     padding: 15px;     cursor: pointer;     border-bottom: 1px solid #26353e; } .menu ul li:hover{     background-color: #4285f4;      } .menu li a{     color: #fff;     font-size: 18px;     text-decoration: none;     } .menu i{     font-size: 27px; } .menu .active{     background-color: #4285f4; } .user{     margin-left: 50px;     padding-bottom:10px ; } .user i{     font-size: 120px;     color: #4285f4; } .user p{     font-weight: bold;     font-size: 18px;     color: #fff; }
       
    • By acneto.frc
      Boa noite a todos.
      Uso Nodejs + express + Mysql
      O retorno abaixo é de retorno da Model quando consultado um registro :id
      Preciso extrair para duas variáveis diferentes a chave  e o valor de um objeto javascripr.
       
      RowDataPacket {
        liv_codigo: 5,
        liv_titulo: 'Guia Mangá - Microprocessadores',
        liv_edicao: '1ª Edição',
        liv_isbn: '987-321',
        liv_ano: 2016,
        aut_codigo: 2,
        edt_codigo: 3,
        liv_ativoinativo: 'A'
      }
       
      Este retorno é resultado da uma consulta SQL  de um registro (:id) na tabela
      Preciso armazenar em arrays diferentes a chave e o valor.
       
      Abraços e obrigado.
       
       
       
    • By Sherlock02
      Olá, Eu preciso criar um menu com dois níveis utilizando Javascript.
      O código está assim:
      <div id="menu">     <ul>        <li>Item 1</li>        <li>Item 2</li>        <li>Item 3</li>        <li>Item 4</li>     </ul> </div>
      Eu preciso transformá-lo em um segundo nível e inserir texto no estilo "Parent 1" no primeiro nível, dessa maneira:
      <div id="menu">     <ul>        <li>Parent 1          <ul class="sub-menu">           <li>Item 1</li>           <li>Item 2</li>           <li>Item 3</li>           <li>Item 4</li>          </ul>     </li>     </ul> </div>  
    • By alex_C1
      1. Para que pagar uma cartoamante para prever o seu futuro? Crie uma função chamada cartoamante que receberá quatro argumentos: número de filhos, nome da esposa ou matido, cidade e função. O retorno da função será: Você ocupará a função X na cidade de Y, vai se casar com Z e terá N filhos. Chame a função passando os quatro parâmetro e imprima o resultado no log. Crie a função no modo tradicional.

      2. Transforme a função anterior em uma arrow function e ajuste o que for necessário no programa.

      Obs: estou precisando dessa parte para terminar meu trabalho da faculdade.
×

Important Information

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