6
function validInteger(theNumber){
    var anyNonDigits = new  RegExp('\D','g');
    if(parseInt(theNumber)&&!anyNonDigits.test(theNumber)){
        return true;
    }else{
        return false;
    }
}

Above is a function I've written to validate some input. I want all positive integers. The problem I'm facing is with the RegExp object. This seems like it should be super simple, but for some reason it's not working.

For example if I pass 'f5' I get true, but if I pass '5f' I get false. I'm also having problems when passing negative numbers. -3 doesn't get caught even if I stringify the variable before passing it into the RegExp. I can fix this by adding '&&parseInt(theNumber)>0' in my if statement, but I feel like the RegExp should catch that too. Thanks in advance!

Frank B
  • 661
  • 1
  • 9
  • 20
  • 1
    The regular expression doesn't work because you need to escape the `\ ` character since `\ ` also has meaning in string literal notation. `new RegExp('\\D','g');` –  Jun 07 '12 at 16:57
  • ...also, you wouldn't really need to `g` modifier, since it sounds as though even one non-digit should be enough to flag the input. –  Jun 07 '12 at 17:17
  • @amnotiam thanks for the info on why what I was doing wasn't working. Regular expressions are something I'm still new to. Hopefully I'll change that soon. – Frank B Jun 07 '12 at 18:24

3 Answers3

11

Simply:

function validInteger(theNumber){    
    return theNumber.match(/^\d+$/) && parseInt(theNumber) > 0;
}

Live DEMO

Or even simpler with regex only as suggested by @Eric:

return /^[0-9]\d*$/.test(theNumber);

Live DEMO

Update:

An excellent cheat sheet. The link died after 5 years, sorry.

gdoron
  • 147,333
  • 58
  • 291
  • 367
1

If it's okay don't use RegExp, you can have:

function validInteger(theNumber){
    var number = +theNumber;

    return number > -1 && number % 1 === 0;
}

Assuming that you consider 0 as positive integer, and you don't want to make a distinction between +0 and -0.

Notice that this function will accept any value for theNumber that can be converted in a Number, so not just "string", and you can pass Number as well of course.

ZER0
  • 24,846
  • 5
  • 51
  • 54
  • Probably you mean `-1 < number`? –  Jun 07 '12 at 17:03
  • @amnotiam. Is there any difference (I know they do different things) between `if(str.match())` and `if (/.../.test(str))`? – gdoron Jun 07 '12 at 17:05
  • @gdoron: Should give the same boolean coerced result. I personally prefer `.test()`. –  Jun 07 '12 at 17:06
0

Be simple!

function validate(num){
    return (num | 0) > 0;
};

This function will return "true" only for positive integers.

sgmonda
  • 2,615
  • 1
  • 19
  • 29