Форум программистов, компьютерный форум, киберфорум
Наши страницы
JavaScript
Войти
Регистрация
Восстановить пароль
 
Рейтинг 5.00/5: Рейтинг темы: голосов - 5, средняя оценка - 5.00
Worse
25 / 21 / 4
Регистрация: 24.10.2011
Сообщений: 166
#1

Почему не запоминается переменная после первого вызова функции ?

08.09.2015, 09:48. Просмотров 814. Ответов 1
Метки нет (Все метки)

В общем есть кнопки и одна последняя кнопка . На них поставил функции по клику менять значение переменной на константу для каждой кнопки свой номер.
нажимаю первую кнопку и в консоле выводится значение переменной ,
а последняя показывает значение переменной кнопка которой была вызвана последней при этом не должна влиять на переменную.

Теперь о проблеме : при повторном нажатии на последнюю кнопку значение переменной меняется почему то .
вот код :
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
<!DOCTYPE html>
<html><head>
    <meta charset="utf-8" lang="ru">
    <style>
body{
    position:absolute;
    margin: 0px;
    border: 0px;
    padding: 0px;
    background-color:rgb(255,255,255);
    width:100vw;
    height:100vh;
}
input{
    width:5vw;
    height:2vh;
    text-align:center;
}
.left{
    position:relative;
    text-align:center;
    width:10vw;
    float:left;
    left:30%
}
.right{
    position:relative;
    text-align:center;
    width:8vw;
    float:right;
    right:30%
}
.center{
    position:relative;
    text-align:center;
    width:10vw;
    left:45%;
}
.nb-button{
    width:4vw;
    height:4vh;
    border-radius:3px;
    margin:3%;
}
#nb-calc{
    position:relative;
    background-color:rgb(125,255,125);
    height:40vh;
    width:90vw;
    left:5vw;
    top:5vh;
    border-radius:100%;
}
#nb-calc-title{
    position:relative;
    color:rgb(0,0,0);
    width:20vw;
    height:2vh;
    left:45%;
}
#nb-symbols{
    position:relative;
    margin-top:5vh;
    padding-left:30%;
}
        </style>
</head><body>
    <div id="nb-calc">
        <b id="nb-calc-title">Калькулятор v.0.0</b>
        <div id="nb-data">
            <div class="left">
                <b>Ввод данных<b>
                <input type="text" id="dataInput" value="0">
            </div>
            <div class="right">
                <b>Память<b>
                <input type="text" id="dataInMemory" value="0">
            </div>
            <div class = "center">
                <b>Вывод данных<b>
                <input type="text" id="nAnswer" value="0">
            </div>
        </div>
        <div id="nb-symbols">
            <input class="nb-button" type="button" onclick="nbAdd()" value="+">
            <input class="nb-button" type="button" onclick="nbSub()" value="-">
            <input class="nb-button" type="button" onclick="nbScale()" value="*">
            <input class="nb-button" type="button" onclick="nbDiv()" value="/">
            <input class="nb-button" type="button" onclick="nbEqual()" value="=">
        </div>
    </div>
    <script>
var nbAnswer = document.getElementById("nAnswer");
var dataInput = document.getElementById("dataInput");
var dataInMemory = document.getElementById("dataInMemory");
var Fnum = 999;
function nbAdd(){
    //dataInMemory.value = parseFloat(dataInMemory.value) + parseFloat(eval(dataInput.value));
    dataInput.value = 0;
    Fnum = 1;
    console.log(Fnum);
}
function nbSub(){
    //dataInMemory.value = parseFloat(dataInMemory.value) - parseFloat(eval(dataInput.value));
    //dataInMemory.value = parseFloat(dataInMemory.value) + parseFloat(eval(dataInput.value));
    dataInput.value = 0;
    Fnum = 2;
    console.log(Fnum);
}
function nbScale(){
    //dataInMemory.value = parseFloat(dataInMemory.value) * parseFloat(eval(dataInput.value));
    //dataInMemory.value = parseFloat(dataInMemory.value) + parseFloat(eval(dataInput.value));
    dataInput.value = 0;
    Fnum = 3;
    console.log(Fnum);
}
function nbDiv(){
    //dataInMemory.value = parseFloat(dataInMemory.value) / parseFloat(eval(dataInput.value));
    //dataInMemory.value = parseFloat(dataInMemory.value) + parseFloat(eval(dataInput.value));
    dataInput.value = 0;
    Fnum = 4;
    console.log(Fnum);
}
function nbEqual(){
    console.log(Fnum);
    if(Fnum = 1){
        nbAnswer.value = parseFloat(dataInMemory.value) + parseFloat(eval(dataInput.value));
        dataInMemory.value = 1;
    }else if(Fnum = 2){
        nbAnswer.value = parseFloat(dataInMemory.value) - parseFloat(eval(dataInput.value));
        dataInMemory.value = 2;
    }else if(Fnum = 3){
        nbAnswer.value = parseFloat(dataInMemory.value) * parseFloat(eval(dataInput.value));
        dataInMemory.value = 3;
    }else if(Fnum = 4){
        nbAnswer.value = parseFloat(dataInMemory.value) / parseFloat(eval(dataInput.value));
        dataInMemory.value = 4;
        }
}
        </script>
</body></html>
0
Лучшие ответы (1)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.09.2015, 09:48
Ответы с готовыми решениями:

Почему callback-функции называются функциями ОБРАТНОГО вызова
Доброго времени. Нуждаюсь в объяснении. Очередной вопрос в стиле «Что такое...

После подключения jQuery перестала работать кнопка вызова функции
В PHP документе использую JavaScript функции. Потребовалось добавить функцию...

Как остановить таймер первого вызова при втором вызове?
доброго времени суток всем есть такая ситуция: function doSmth(arg1,...

Почему не нарастает переменная?
Структура страницы - фреймы. Объявлены так: &lt;frameset rows='120,*' border='0'&gt;...

Почему глобальная переменная не изменяется из функции?
Здравствуйте! Делаю такую программу. Сначала создаю анимацию - увеличение...

1
vovandr
630 / 518 / 194
Регистрация: 19.08.2013
Сообщений: 1,400
08.09.2015, 10:10 #2
Лучший ответ Сообщение было отмечено Worse как решение

Решение

Вы должны понимать, что это:
Javascript
1
if(Fnum = 1)
И это:
Javascript
1
if(Fnum == 1)
совершенно разные вещи.
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.09.2015, 10:10

Ajax после вызова надо удалять?
ajax после вызова надо удалять? Это же объект. Он не будет переполнять память...

Глобальная переменная после вызова функции меняет значение
До flag = 0; odnorod_pril(buffer1); После int odnorod_pril(char *buffer) {...

Как подменить определение функции после первого вызова без использования if и функторов
в разных модулях есть 2 синглетона, которым нужны ссылки друг на друга, один из...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru