27

I have this javascript function to validate if a number is greater than another number

function validateForm() {
    var x = document.forms["frmOrder"]["txtTotal"].value;
    var y = document.forms["frmOrder"]["totalpoints"].value;

    if (x > y) {
        alert("Sorry, you don't have enough points");
        return false;
    }
}

It's not working for some reason.

If I do alert(x) I get 1300, and alert(y) gives 999

This works....

function validateForm() {
    var x = 1300;
    var y = 999;

    if (x > y) {
        alert("Sorry, you don't have enough points");
        return false;
    }
}
sachleen
  • 30,730
  • 8
  • 78
  • 73
JakeKempo
  • 580
  • 1
  • 5
  • 14

4 Answers4

73

You should convert them to number before compare.

Try:

if (+x > +y) {
  //...
}

or

if (Number(x) > Number(y)) {
  // ...
}

Note: parseFloat and pareseInt(for compare integer, and you need to specify the radix) will give you NaN for an empty string, compare with NaN will always be false, If you don't want to treat empty string be 0, then you could use them.

xdazz
  • 158,678
  • 38
  • 247
  • 274
3

You can "cast" to number using the Number constructor..

var number = new Number("8"); // 8 number

You can also call parseInt builtin function:

var number = parseInt("153"); // 153 number
edrian
  • 4,501
  • 5
  • 31
  • 35
  • Ooops, using Number as a constructor returns a Number object, and an object is only ever "equal" to itself, so `new Number('7') == new Number('7')` returns `false`. I think you meant to use it as a function, so `Number('7') == Number('7')`. And `parseInt` should always use a radix: `parseInt('153',10)`. – RobG Oct 26 '12 at 01:46
  • Ohh!, you are right @RobG about the "=="!! .. I tested these cases and were fine, and I suposed that Number object was always being calling "toString()" implicitly (actually, I think internally its calling valueOf() method): new Number('725') < new Number('800'); //Outputs true new Number('91') > new Number('90'); //Outputs true new Number('7') < new Number('7'); //Outputs false new Number('7') > new Number('8'); //Outputs false new Number('8') < new Number('7'); //Outputs false But for equals, in this way, you need: new Number('7').valueOf() == new Number('7').valueOf(); //Outputs true – edrian Oct 26 '12 at 03:22
3

You're comparing strings. JavaScript compares the ASCII code for each character of the string.

To see why you get false, look at the charCodes:

"1300".charCodeAt(0);
49
"999".charCodeAt(0);
57

The comparison is false because, when comparing the strings, the character codes for 1 is not greater than that of 9.

The fix is to treat the strings as numbers. You can use a number of methods:

parseInt(string, radix)
parseInt("1300", 10);
> 1300 - notice the lack of quotes


+"1300"
> 1300


Number("1300")
> 1300
sachleen
  • 30,730
  • 8
  • 78
  • 73
1

Do this.

var x=parseInt(document.forms["frmOrder"]["txtTotal"].value);
var y=parseInt(document.forms["frmOrder"]["totalpoints"].value);
specialscope
  • 4,188
  • 3
  • 24
  • 22