0

When ever a user forgets to put a number in an input i want it to set the value for that input to zero to prevent the NaN

i have tried looking it up the only thing i got close was using the if statement along with the alert telling the user the error but i would like it to be more user friendly to make it still execute if a field is empty but that wont work if the any of then come back as a NaN and to make it where a blank field is set to a value of zero here is the code below: https://code.sololearn.com/WD419jEp6C3Q/?ref=app

23rd Feb 2018, 7:40 AM
Brennan Woodroof
Brennan Woodroof - avatar
3 Answers
+ 9
you can add || 0 to any one of you inputs in JS for example var q = parseInt(document.getElementById('qr').value) || 0; and think about restructuring a bit for instance make another function that extract a value from HTML element function getValue(el){ return parseInt(el.value) || 0; } var q = getValue(document.getElementById('qr')); or even just pass the id to the function and use getElementById inside the function the point is that it would make it easier for you if you break down the code to smaller functions that handles same logic.
23rd Feb 2018, 8:15 AM
Burey
Burey - avatar
+ 6
I guess you can check the input value and verify whether a number or anything at all was there or not, if the input is blank change the value to zero before calling parseInt and process the change output. Good luck!
23rd Feb 2018, 8:06 AM
Ipang
+ 3
just a small suggestion. in order for the user not to leave the input field empty, you can add the attribute "required" to the input tag. this way the browser will warn you that the left out field has to be filled in order to proceed.
23rd Feb 2018, 9:38 AM
storm
storm - avatar