Как предотвратить несколько десятичных знаков в калькуляторе JavaScript - PullRequest
0 голосов
/ 04 ноября 2018

Я делаю калькулятор JavaScript и у меня проблемы с десятичными числами. Мне нужно, чтобы они выводились только один раз. Я покажу пример с точками (мне нужно 0,55, а код может составлять 0 .... 5). Этот код выводит " «. сразу после нажатия на какое-то число, после этого вы можете нажать на символ "." и он напишет много точек в txtbox. Вот только одна часть моего кода, которая вам нужна

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
<style>
    button {
        user-select: none; 
        font-size:23px; 
        width:80px ; 
        height: 70px; 
        font-family:bold;
        border-radius: 50%;
        border-color: gray;
    }
    .ope{
        background: rgb(96, 250, 199);
    }
    .num:focus {
        background: lime;
    }

</style>
</head>

<body>
<input id="txtBox" type="text" style="text-align: right;font-size:60px;width: 325px;height: 125px; font-family: bold;" />
<br />
<button onclick="Click(event)" class="ope">C</button>
<button onclick="Click(event)" class="ope">delete</button>
<button onclick="Click(event)" class="ope">+/-</button>
<button onclick="Click(event)" class="ope">+</button>

<br />

<button onclick="Click(event)" class="num">1</button>
<button onclick="Click(event)" class="num">2</button>
<button onclick="Click(event)" class="num">3</button>
<button onclick="Click(event)" class="ope">-</button>

<br />

<button onclick="Click(event)" class="num">4</button>
<button onclick="Click(event)" class="num">5</button>
<button onclick="Click(event)" class="num">6</button>
<button onclick="Click(event)" class="ope">*</button>

<br />

<button onclick="Click(event)" class="num">7</button>
<button onclick="Click(event)" class="num">8</button>
<button onclick="Click(event)" class="num">9</button>
<button onclick="Click(event)" class="ope">/</button>

<br />

<button onclick="Click(event)" class="num">0</button>
<button onclick="Click(event)" id="ope">.</button>
<button onclick="Click(event)" id="equalto" style="background: rgb(206, 37, 206);user-select: none;font-size:25px; width:160px ; height: 70px; font-family:bold;">=</button>

<script>
    var nums = document.getElementById("num")
    var operator = document.getElementById("ope")
    var textbox = document.getElementById("txtBox")
    var counter = 0

    function Click(e) {
        var but = e.target;
        var maxamount = 9;
        var dot = 1
        if (but.innerText != "=" && but.innerText != "delete") {
            textbox.value += but.innerText
            if (but.innerText == "C") {
                textbox.value = "0"
            }
            else if (textbox.value[0] == "." || textbox.value[0] == "0" || textbox.value[0] == "+" || textbox.value[0] == "-" || textbox.value[0] == "/" || textbox.value[0] == "*") {
                textbox.value = ""
            }
            else if (textbox.value.length > maxamount) {
                textbox.value = textbox.value.substring(0, maxamount)
            }
            else if (textbox.value.includes == "+/-") {
                textbox.value*= -1
            }
            if (!textbox.value.includes('.') && textbox.value != "") {
                textbox.value+="."
            }
            else{

            }
        }

        else {
            textbox.value = eval(textbox.value)
        }
        if (but.innerText == "delete") {
            textbox.value = textbox.value.substring(0, textbox.value.length - 1);
        }
        if (textbox.value == "NaN" || textbox.value == "undefine") {
            textbox.value = ""
        }

    }
</script>
</body>

</html>

Ответы [ 2 ]

0 голосов
/ 04 ноября 2018

Я думаю, что ваша проблема с условиями (ваш код рассматривает кнопку точка как другие кнопки и, следовательно, каждый раз выводит "." ). Вы должны добавить условие для кнопки dot . Вы можете переписать свой код следующим образом:

var textbox = document.getElementById("txtBox")

function Click(e) {
  var but = e.target;
  if (but.innerText != "=" && but.innerText != "delete") {
     if (but.innerText == ".") {
        if (!textbox.value.includes('.') && textbox.value != "") {
           textbox.value += "."
        }
     }
     else{
        textbox.value += but.innerText
     }
  }
}

Надеюсь, это поможет.

0 голосов
/ 04 ноября 2018
  Please try below Click function,

      <script>
        var nums = document.getElementById("num");
        var operator = document.getElementById("ope");
        var textbox = document.getElementById("txtBox");
        var counter = 0
        var dotReset=true;
        function Click(e) {
            var but = e.target;
            var maxamount = 9;
            var dot = 1;

            if (but.innerText != "=" && but.innerText != "delete") {
                if (but.innerText != ".") {
                    textbox.value += but.innerText;
                    if (but.innerText == "+" || but.innerText == "-" || but.innerText == "*" || but.innerText == "/"){
                        dotReset=true;
                    }
                }

                if (but.innerText == "C") {
                    textbox.value = "0";
                    dotReset=true;
                }
                else if (textbox.value[0] == "." || textbox.value[0] == "0" || textbox.value[0] == "+" || textbox.value[0] == "-" || textbox.value[0] == "/" || textbox.value[0] == "*") {
                    textbox.value = "";
                    dotReset=true;
                }
                else if (textbox.value.length > maxamount) {
                    textbox.value = textbox.value.substring(0, maxamount);
                }
                else if (textbox.value.includes == "+/-") {
                    textbox.value*= -1;
                }
                if (but.innerText == ".") {

                    if(dotReset){
                        if (textbox.value != "") {
                                textbox.value+="."
                                dotReset=false;
                            }
                    }

                    }
            }
            else {
                textbox.value = eval(textbox.value)
            }
            if (but.innerText == "delete") {
                textbox.value = textbox.value.substring(0, textbox.value.length - 1);
            }
            if (textbox.value == "NaN" || textbox.value == "undefine") {
                textbox.value = ""
            }

        }
    </script>
...