javascript如何验证数字这正整数?

如题所述

  之前记录过JavaScript中判断为数字类型的多种方式,这篇看看如何判断为整数类型(Integer)。
  JavaScript中不区分整数和浮点数,所有数字内部都采用64位浮点格式表示,和Java的double类型一样。但实际操作中比如数组索引、位操作则是基于32位整数。
  取整的方法可以按照下面的五种来进行。
  
  方式一、使用取余运算符判断
  任何整数都会被1整除,即余数是0。利用这个规则来判断是否是整数。
  function isInteger(obj) {
  return obj%1 === 0
  }
  isInteger(3) // true
  isInteger(3.3) // false
  

  以上输出可以看出这个函数挺好用,但对于字符串和某些特殊值显得力不从心
  isInteger('') // true
  isInteger('3') // true
  isInteger(true) // true
  isInteger([]) // true
  

  对于空字符串、字符串类型数字、布尔true、空数组都返回了true,真是难以接受。对这些类型的内部转换细节感兴趣的请参考:JavaScript中奇葩的假值
  因此,需要先判断下对象是否是数字,比如加一个typeof
  function isInteger(obj) {
  return typeof obj === 'number' && obj%1 === 0
  }
  isInteger('') // false
  isInteger('3') // false
  isInteger(true) // false
  isInteger([]) // false
  
  二、使用Math.round、Math.ceil、Math.floor判断
  整数取整后还是等于自己。利用这个特性来判断是否是整数,Math.floor示例,如下
  function isInteger(obj) {
  return Math.floor(obj) === obj
  }
  isInteger(3) // true
  isInteger(3.3) // false
  isInteger('') // false
  isInteger('3') // false
  isInteger(true) // false
  isInteger([]) // false

  这个直接把字符串,true,[]屏蔽了,代码量比上一个函数还少。
  
  三、通过parseInt判断
  function isInteger(obj) {
  return parseInt(obj, 10) === obj
  }
  isInteger(3) // true
  isInteger(3.3) // false
  isInteger('') // false
  isInteger('3') // false
  isInteger(true) // false
  isInteger([]) // false
  

  但也有一个缺点
  isInteger(1000000000000000000000) // false

  原因是parseInt在解析整数之前强迫将第一个参数解析成字符串。
  
  四、通过位运算判断
  function isInteger(obj) {
  return (obj | 0) === obj
  }
  isInteger(3) // true
  isInteger(3.3) // false
  isInteger('') // false
  isInteger('3') // false
  isInteger(true) // false
  isInteger([]) // false
  

  这个函数位运算只能处理32位以内的数字,对于超过32位的无能为力,如
  isInteger(Math.pow(2, 32)) // 32位以上的数字返回false了
  
  五、ES6提供了Number.isInteger
  Number.isInteger(3) // true
  Number.isInteger(3.1) // false
  Number.isInteger('') // false
  Number.isInteger('3') // false
  Number.isInteger(true) // false
  Number.isInteger([]) // false
  
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-11-22
<script type="text/javascript">
function test(){
var num=document.getElementById("numId").value;/*假设你输入数字的文本框取的id设为:id=numId,或者这里用:document.form的名字.文本框的名字.value;*/
if(num>=0)
return true;
else
return false;
}
</script>本回答被网友采纳
第2个回答  2013-11-22
用正则表达式最好!
<script type="text/javascript">
function ckIsNum(){
str=document.getElementById("txt").value //txt是某个文本框的ID值
var cknum=/^[1-9]\d*$/
if(!cknum.test(str)){
alert("输入的不是正确的数字!")
return false;
}
}
</script>
第3个回答  2013-11-22
正则 正解!
但是稍微复杂了点。
判断正整数
1.为正数
2.为整数
var TestNum = ? //取得数字
if(TesyNum>0 && parseInt(TestNum )== TestNum ){
alert(恭喜测试通过)
}
else{
alert(不通过)

}
相似回答