Невозможно добавить формат валюты к общему количеству входных данных
Вот мой вопрос: мне нужно сложить 3 входа, а затем они должны отображаться на четвертом входе "итого". Значение всех этих входных данных должно быть отформатировано как валюта.
В коде, который я прикрепил, сумма сделана хорошо, и я получаю отформатировать 3 первых ввода, но не общий ввод
Может ли кто-нибудь иметь представление о том, как это сделать? как я могу добавить формат к общему вводу?
Спасибо! Береги себя!
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
<style>
html {
box-sizing: border-box;
font-family: 'PT Sans', sans-serif;
-webkit-font-smoothing: antialiased;
}
*,
*:before,
*:after {
box-sizing: inherit;
}
body {
background-color: #f3f3f3;
}
form {
width: 100%;
max-width: 300px;
margin: 60px auto;
}
form input {
font-size: 30px;
padding: 0;
border: 2px solid #ccc;
border-left: 0;
width: 100%;
color: #666;
border-radius: 0 7px 7px 0;
font-family: 'PT Sans', sans-serif;
font-weight: bold;
}
form input:focus {
outline: 0;
}
form input.error {
border-color: #ff0000;
}
form label.error {
background-color: #ff0000;
color: #fff;
padding: 6px;
font-size: 11px;
}
label {
color: #999;
display: block;
margin-bottom: 10px;
text-transform: uppercase;
font-size: 18px;
font-weight: bold;
letter-spacing: 0.05em
}
.flex {
display: flex;
justify-content: flex-start;
}
.flex input {
max-width: 300px;
flex: 1 1 300px;
}
.flex .currency {
font-size: 30px;
padding: 0 10px 0 20px;
color: #999;
border: 2px solid #ccc;
border-right: 0;
line-height: 2.5;
border-radius: 7px 0 0 7px;
background: white;
}
</style>
<script>
(function($, undefined) {
"use strict";
// When ready.
$(function() {
var $form = $( "#form" );
var $input = $form.find( "input" );
$input.on( "keyup", function( event ) { //a function when the user presses then releases a keyboard key.
//When user select text in the document, also abort.
var selection = window.getSelection().toString();
if ( selection !== '' ) {
return;
}
// When the arrow keys are pressed, abort.
if ( $.inArray( event.keyCode, [38,40,37,39] ) !== -1 ) {
return;
}
var $this = $( this );
//Retrieve the value from the input.
var input = $this.val();
var input = input.replace(/[\D\s\._\-]+/g, ""); //Sanitize the value using RegEx by removing unnecessary characters such as spaces, underscores, dashes, and letters.
input = input ? parseInt( input, 10 ) : 0; // function to make sure the value is an integer (a round number).
$this.val( function() {
return ( input === 0 ) ? "" : input.toLocaleString( "de-DE" ); //Add the thousand separator with the toLocaleString() function, then pass the sanitised value back to the input element.
} );
} );
/**
* ==================================
* When Form Submitted
* ==================================
*/
$form.on( "submit", function( event ) {
var $this = $( this );
var arr = $this.serializeArray();
for (var i = 0; i < arr.length; i++) {
arr[i].value = arr[i].value.replace(/[($)\s\._\-]+/g, '');
};
console.log( arr );
event.preventDefault();
});
});
})(jQuery);
function sumar() { // input sum
var total = 0;
$(".monto").each(function() {
if (isNaN(parseFloat($(this).val()))) {
total += 0;
} else {
var $this = $( this );
var input = $this.val();
var input = input.replace(/[\D\s\._\-]+/g, ""); //Sanitize the value again so that the sum can be made
input = input ? parseInt( input, 10 ) : 0;
total += input; //Sum input and put it in total variable
}
});
//alert(total);
document.getElementById('amount').value = total; // deliver the total value to the input "id=amount"
}
</script>
</head>
<body>
<form id="form" method="post" action="">
<label>Valor #1</label> <br>
<div class="flex">
<span class="currency">$</span>
<input type="text" id="txt_campo_1" class="monto" onkeyup="sumar();">
</div>
<br>
<label>Valor #2</label><br>
<div class="flex">
<span class="currency">$</span>
<input type="text" id="txt_campo_2" class="monto" onkeyup="sumar();">
</div>
<br>
<label>Valor #3</label> <br>
<div class="flex">
<span class="currency">$</span>
<input type="text" id="txt_campo_3" class="monto" onkeyup="sumar();">
</div> <br>
<label for="amount">Enter amount</label>
<div class="flex">
<span class="currency">$</span>
<input id="amount" name="amount" type="text" maxlength="15" />
</div>
</form>
</body>
</html>
2 ответа
Отформатируйте значение общего ввода с помощью:
document.getElementById('amount').value = total.toLocaleString( "de-DE" );
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
<style>
html {
box-sizing: border-box;
font-family: 'PT Sans', sans-serif;
-webkit-font-smoothing: antialiased;
}
*,
*:before,
*:after {
box-sizing: inherit;
}
body {
background-color: #f3f3f3;
}
form {
width: 100%;
max-width: 300px;
margin: 60px auto;
}
form input {
font-size: 30px;
padding: 0;
border: 2px solid #ccc;
border-left: 0;
width: 100%;
color: #666;
border-radius: 0 7px 7px 0;
font-family: 'PT Sans', sans-serif;
font-weight: bold;
}
form input:focus {
outline: 0;
}
form input.error {
border-color: #ff0000;
}
form label.error {
background-color: #ff0000;
color: #fff;
padding: 6px;
font-size: 11px;
}
label {
color: #999;
display: block;
margin-bottom: 10px;
text-transform: uppercase;
font-size: 18px;
font-weight: bold;
letter-spacing: 0.05em
}
.flex {
display: flex;
justify-content: flex-start;
}
.flex input {
max-width: 300px;
flex: 1 1 300px;
}
.flex .currency {
font-size: 30px;
padding: 0 10px 0 20px;
color: #999;
border: 2px solid #ccc;
border-right: 0;
line-height: 2.5;
border-radius: 7px 0 0 7px;
background: white;
}
</style>
<script>
(function($, undefined) {
"use strict";
// When ready.
$(function() {
var $form = $( "#form" );
var $input = $form.find( "input" );
$input.on( "keyup", function( event ) { //a function when the user presses then releases a keyboard key.
//When user select text in the document, also abort.
var selection = window.getSelection().toString();
if ( selection !== '' ) {
return;
}
// When the arrow keys are pressed, abort.
if ( $.inArray( event.keyCode, [38,40,37,39] ) !== -1 ) {
return;
}
var $this = $( this );
//Retrieve the value from the input.
var input = $this.val();
var input = input.replace(/[\D\s\._\-]+/g, ""); //Sanitize the value using RegEx by removing unnecessary characters such as spaces, underscores, dashes, and letters.
input = input ? parseInt( input, 10 ) : 0; // function to make sure the value is an integer (a round number).
$this.val( function() {
return ( input === 0 ) ? "" : input.toLocaleString( "de-DE" ); //Add the thousand separator with the toLocaleString() function, then pass the sanitised value back to the input element.
} );
} );
/**
* ==================================
* When Form Submitted
* ==================================
*/
$form.on( "submit", function( event ) {
var $this = $( this );
var arr = $this.serializeArray();
for (var i = 0; i < arr.length; i++) {
arr[i].value = arr[i].value.replace(/[($)\s\._\-]+/g, '');
};
console.log( arr );
event.preventDefault();
});
});
})(jQuery);
function sumar() { // input sum
var total = 0;
$(".monto").each(function() {
if (isNaN(parseFloat($(this).val()))) {
total += 0;
} else {
var $this = $( this );
var input = $this.val();
var input = input.replace(/[\D\s\._\-]+/g, ""); //Sanitize the value again so that the sum can be made
input = input ? parseInt( input, 10 ) : 0;
total += input; //Sum input and put it in total variable
}
});
//alert(total);
document.getElementById('amount').value = total.toLocaleString( "de-DE" ); // deliver the total value to the input "id=amount"
}
</script>
</head>
<body>
<form id="form" method="post" action="">
<label>Valor #1</label> <br>
<div class="flex">
<span class="currency">$</span>
<input type="text" id="txt_campo_1" class="monto" onkeyup="sumar();">
</div>
<br>
<label>Valor #2</label><br>
<div class="flex">
<span class="currency">$</span>
<input type="text" id="txt_campo_2" class="monto" onkeyup="sumar();">
</div>
<br>
<label>Valor #3</label> <br>
<div class="flex">
<span class="currency">$</span>
<input type="text" id="txt_campo_3" class="monto" onkeyup="sumar();">
</div> <br>
<label for="amount">Enter amount</label>
<div class="flex">
<span class="currency">$</span>
<input id="amount" name="amount" type="text" maxlength="15" />
</div>
</form>
</body>
</html>
Я добавляю этот код при вызове моей суммы ввода, и это сработало! "document.getElementById ('amount'). value = total.toLocaleString (" de-DE ");" всем спасибо
<!DOCTYPE html>
<html>
<head>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.3/jquery.min.js"></script>
<style>
html {
box-sizing: border-box;
font-family: 'PT Sans', sans-serif;
-webkit-font-smoothing: antialiased;
}
*,
*:before,
*:after {
box-sizing: inherit;
}
body {
background-color: #f3f3f3;
}
form {
width: 100%;
max-width: 300px;
margin: 60px auto;
}
form input {
font-size: 30px;
padding: 0;
border: 2px solid #ccc;
border-left: 0;
width: 100%;
color: #666;
border-radius: 0 7px 7px 0;
font-family: 'PT Sans', sans-serif;
font-weight: bold;
}
form input:focus {
outline: 0;
}
form input.error {
border-color: #ff0000;
}
form label.error {
background-color: #ff0000;
color: #fff;
padding: 6px;
font-size: 11px;
}
label {
color: #999;
display: block;
margin-bottom: 10px;
text-transform: uppercase;
font-size: 18px;
font-weight: bold;
letter-spacing: 0.05em
}
.flex {
display: flex;
justify-content: flex-start;
}
.flex input {
max-width: 300px;
flex: 1 1 300px;
}
.flex .currency {
font-size: 30px;
padding: 0 10px 0 20px;
color: #999;
border: 2px solid #ccc;
border-right: 0;
line-height: 2.5;
border-radius: 7px 0 0 7px;
background: white;
}
</style>
<script>
(function($, undefined) {
"use strict";
// When ready.
$(function() {
var $form = $( "#form" );
var $input = $form.find( "input" );
$input.on( "keyup", function( event ) { //a function when the user presses then releases a keyboard key.
//When user select text in the document, also abort.
var selection = window.getSelection().toString();
if ( selection !== '' ) {
return;
}
// When the arrow keys are pressed, abort.
if ( $.inArray( event.keyCode, [38,40,37,39] ) !== -1 ) {
return;
}
var $this = $( this );
//Retrieve the value from the input.
var input = $this.val();
var input = input.replace(/[\D\s\._\-]+/g, ""); //Sanitize the value using RegEx by removing unnecessary characters such as spaces, underscores, dashes, and letters.
input = input ? parseInt( input, 10 ) : 0; // function to make sure the value is an integer (a round number).
$this.val( function() {
return ( input === 0 ) ? "" : input.toLocaleString( "de-DE" ); //Add the thousand separator with the toLocaleString() function, then pass the sanitised value back to the input element.
} );
} );
/**
* ==================================
* When Form Submitted
* ==================================
*/
$form.on( "submit", function( event ) {
var $this = $( this );
var arr = $this.serializeArray();
for (var i = 0; i < arr.length; i++) {
arr[i].value = arr[i].value.replace(/[($)\s\._\-]+/g, '');
};
console.log( arr );
event.preventDefault();
});
});
})(jQuery);
function sumar() { // input sum
var total = 0;
$(".monto").each(function() {
if (isNaN(parseFloat($(this).val()))) {
total += 0;
} else {
var $this = $( this );
var input = $this.val();
var input = input.replace(/[\D\s\._\-]+/g, ""); //Sanitize the value again so that the sum can be made
input = input ? parseInt( input, 10 ) : 0;
total += input; //Sum input and put it in total variable
}
});
//alert(total);
document.getElementById('amount').value = total.toLocaleString( "de-DE" ); // deliver the total value to the input "id=amount"
}
</script>
</head>
<body>
<form id="form" method="post" action="">
<label>Valor #1</label> <br>
<div class="flex">
<span class="currency">$</span>
<input type="text" id="txt_campo_1" class="monto" onkeyup="sumar();">
</div>
<br>
<label>Valor #2</label><br>
<div class="flex">
<span class="currency">$</span>
<input type="text" id="txt_campo_2" class="monto" onkeyup="sumar();">
</div>
<br>
<label>Valor #3</label> <br>
<div class="flex">
<span class="currency">$</span>
<input type="text" id="txt_campo_3" class="monto" onkeyup="sumar();">
</div> <br>
<label for="amount">Total amount</label>
<div class="flex">
<span class="currency">$</span>
<input id="amount" name="amount" type="text" maxlength="15" />
</div>
</form>
</body>
</html>