开发者

Check string for integer

开发者 https://www.devze.com 2023-02-04 14:02 出处:网络
I want to validate a input field. The user should type in a phone number with minimum length of 10 d开发者_运维百科igits.

I want to validate a input field. The user should type in a phone number with minimum length of 10 d开发者_运维百科igits.

So I need to check for illegal chars. It would be nice just to check wheather the input is an integer or not.

I came up with this but it does not work (n would be the string).

function isInt(n){
    return typeof n== 'number' && n%1==0;
}

Any ideas?


You can do a test like this:

input.length >= 10 && /^[0-9]+$/.test(input)

That will fail if there are non-digits in the string or the string is less than 10 chars long


This should work((input - 0) automatically tries to convert the value to a number):

function isInt(input){
   return ((input - 0) == input && input % 1==0);
}

There is already an SO-question about this issue: Validate decimal numbers in JavaScript - IsNumeric()


Might be an overkill for you, but Google has not too long ago announced a library for phone validation. Java and Javascript variants are available.


Validating a phone number is a little more complicated than checking if the input is an integer. As an example phone numbers can and do begin with zeros so it isn't technically and int. Also users may enter dashes: For example:

00 34 922-123-456

So, as for validating it you have a couple of options:

  • Use regex expression to validate, have a look at:

    http://regexlib.com/

    this site will have hundreds of examples

  • Use looping to check each characters in turn, i.e. is character int or dash

I would recommend the former as the latter depends on consistent input from users and you aren't going to get that


Why not use:

return (+val === ~~val && null !== val);

as a return in your function?

this is the output of the javascript console

> +"foobar" === ~~"foobar"
  false
> +1.6 === ~~1.6
  false
> +'-1' === ~~'-1'
  true
> +'-1.56' === ~~'-1.56'
  false
> +1 === ~~1
  true
> +-1 === ~~-1
  true
> +null === ~~null // this is why we need the "&& null !== val" in our return call
  true 
0

精彩评论

暂无评论...
验证码 换一张
取 消