Reputation: 35
I'm getting a NaN error in this calculator script: Any ideas?
Here is the whole html in a text format:
https://www.dropbox.com/s/i3u429bn5bjd4i9/orecalculator.txt
<script language="JavaScript">
var IDs = [22,17425,17426,1223,17428,17429,1225,17432,17433,1232,17436,17437,1229,17865,17866,21,17440,17441,1231,17444,17445,1226,17448,17449,20,17452,17453,11396,17869,17870,1227,17867,17868,18,17455,17456,1224,17459,17460,1228,17463,17464,19,17466,17467,1230,17470,17471];
function calculate(i){
while (i + 1 < IDs.length) {
var y=document.getElementById('reward');
var x=document.getElementById(IDs[i]);
y.value=parseInt(y.value)+parseInt(x.value);
i++;
}
}
</script>
Upvotes: 1
Views: 704
Reputation: 2671
I have Run this code in console and found following output
document.getElementById('reward')
//output <input type="text" id="reward">
document.getElementById('reward').value
//""
parseInt(document.getElementById('reward').value)
//NaN
parseInt("")
//NaN
Explanation
parseInt of empty string is NaN
Solution
Use
Reward: <input type="text" id="reward" value="0">
instead
Reward: <input type="text" id="reward">
Fixed: JS Code
function calculate(i){
while (i + 1 < IDs.length) {
var y=document.getElementById('reward');
var x=document.getElementById(IDs[i]);
y.value=parseInt(y.value|0)+parseInt(x.value|0);
i++;
}
}
Upvotes: 3
Reputation: 4413
untested but should be something like this:
calculate = function (i){
var y = document.getElementById('reward');
var x = 0;
while (i + 1 < IDs.length) {
var elm = document.getElementById(IDs[i]);
x+=parseInt(elm.value||0);
i++;
}
y.value = x;
};
working fiddle:
http://jsfiddle.net/g30rg3/8ADQX/
Upvotes: 0