在JavaScript中判断整型的N种方法示例介绍


Posted in Javascript onJune 18, 2014

整数类型(Integer)在JavaScript经常会导致一些奇怪的问题。在ECMAScript的规范中,他们只存在于概念中:

所有的数字都是浮点数,并且整数只是没有一组没有小数的数字。

在这篇博客中,我会解释如何去检查某个值是否为整型。
ECMAScript 5

在ES5中有很多方法你可以使用。有时侯,你可能想用自己的方法:一个isInteger(x)的函数,如果是整型返回true,否则返回false.

让我们看看一些例子。

通过余数检查

你可以使用余数运算(%),将一个数字按1求余,看看余数是不是0。

function isInteger(x) {
  return x % 1 === 0;
}

我喜欢这个方法,因为它非常简单,而且有效。

> isInteger(17)
true
> isInteger(17.13)
false

在操作余数运算时你得小心一点,因为结果取决于第一个数的符号,如果是正的,结果就是正的;否则就是负的。

> 3.5 % 1
0.5
> -3.5 % 1
-0.5

然后,我们也可以检查0,这其实不是一个问题。但问题是:这个方法对非数字也会返回true,因为 % 会将它转换成数字:

> isInteger('')
true
> isInteger('33')
true
> isInteger(false)
true
> isInteger(true)
true

可以通过很简单的类型检查来解决:

function isInteger(x) {
  return (typeof x === 'number') && (x % 1 === 0);
}

通过Math.round() 如果一个数字取整以后还跟之前的值一样,那么它就是整数。在JavaScript中可以通过Math.round()来检查:

function isInteger(x) {
  return Math.round(x) === x;
}

这个方法也不错

> isInteger(17)
true
> isInteger(17.13)
false

它也可以判断非数字,因为Math.round()总是返回数字,并且===只有当类型一样时才返回true.

> isInteger('')
false

如果你想让代码更清晰一点,你可以添加类型检查(就是我们在之前版本做的)。另外,Math.floor()和Math.ceil()可以像Math.round()一样工作。 通过位操作检查 位操作符提供另外一种“取整”的方法:

function isInteger(x) {
  return (x | 0) === x;
}

这个解决方案(跟其它位运算一样)有一个缺陷:它无法处理超过32位的数字。

> isInteger(Math.pow(2, 32))
false

通过parseInt()检查 parseInt()也提供了跟Math.round()类似将数字转换成整型的方法。 让我们看看这个方法为什么不错。

function isInteger(x) {
  return parseInt(x, 10) === x;
}

像Math.round()解决方案一样,它也可以处理非数字的情况,但是它也不能正确地处理所有的整型数字:

> isInteger(1000000000000000000000)
false

为什么?parseInt()在解析整数之前强迫将第一个参数解析成字符串。因此使用这种方法将数字转换成整型不是一个好的选择。

> parseInt(1000000000000000000000, 10)
1
> String(1000000000000000000000)
'1e+21'

就像上面那样,parseInt()在解析'1e+21'时在1处停止处理了,所以它才会返回1. ECMAScript 6 对于Math.round()扔补充,ES6提供了另外一个将数字转换成整型的方法:Math.trunc()。该函数会移除数字的小数部分。

> Math.trunc(4.1)
4
> Math.trunc(4.9)
4
> Math.trunc(-4.1)
-4
> Math.trunc(-4.9)
-4

此外,ECMAScript6不需要去处理检查整数那些琐碎的任务,因为它带有一个内置函数 Number.isInteger()。

Javascript 相关文章推荐
JavaScript 直接操作本地文件的实现代码
Dec 01 Javascript
jsp+javascript打造级连菜单的实例代码
Jun 14 Javascript
在Firefox下js select标签点击无法弹出
Mar 06 Javascript
JavaScript日期时间格式化函数分享
May 05 Javascript
js 动态修改css文件用到了cssRule
Aug 20 Javascript
JavaScript bold方法入门实例(把指定文字显示为粗体)
Oct 17 Javascript
js显示文本框提示文字的方法
May 07 Javascript
PHP7新特性简述
Jun 11 Javascript
Node.js实现文件上传的示例
Jun 28 Javascript
vue2.X组件学习心得(新手必看篇)
Jul 05 Javascript
微信小程序基于ColorUI构建皮皮虾短视频去水印组件
Nov 04 Javascript
js属性对象的hasOwnProperty方法的使用
Feb 05 Javascript
input标签内容改变的触发事件介绍
Jun 18 #Javascript
jQuery控制TR显示隐藏的几种方法
Jun 18 #Javascript
对 jQuery 中 data 方法的误解分析
Jun 18 #Javascript
浅谈 jQuery 事件源码定位问题
Jun 18 #Javascript
js调试系列 源码定位与调试[基础篇]
Jun 18 #Javascript
js调试系列 控制台命令行API使用方法
Jun 18 #Javascript
js调试系列 初识控制台
Jun 18 #Javascript
You might like
PHP和.net中des加解密的实现方法
2013/02/27 PHP
PHP多文件上传实例
2015/07/09 PHP
PHP生成短网址的思路以及实现方法的详解
2019/03/25 PHP
IE 缓存策略的BUG的解决方法
2007/07/21 Javascript
使用原生javascript创建通用表单验证——更锋利的使用dom对象
2011/09/13 Javascript
用dtree实现树形菜单 dtree使用说明
2011/10/17 Javascript
JavaScript高级程序设计 阅读笔记(十二) js内置对象Math
2012/08/14 Javascript
Javascript模块化编程(一)模块的写法最佳实践
2013/01/17 Javascript
js读写(删除)Cookie实例详解
2013/04/17 Javascript
给文字加上着重号的JS代码
2013/11/12 Javascript
javascript 中__proto__和prototype详解
2014/11/25 Javascript
jQuery实现的导航动画效果(附demo源码)
2016/04/01 Javascript
jQuery实现可拖拽3D万花筒旋转特效
2017/01/03 Javascript
JS实现直接运行html代码的方法
2017/03/13 Javascript
新手必须知的Node.js 4个JavaScript基本概念
2018/09/16 Javascript
node.js使用fs读取文件出错的解决方案
2019/10/23 Javascript
JavaScript制作3D旋转相册
2020/08/02 Javascript
vue项目引入ts步骤(小结)
2019/10/31 Javascript
Python中返回字典键的值的values()方法使用
2015/05/22 Python
python图片验证码生成代码
2016/07/02 Python
Java及python正则表达式详解
2017/12/27 Python
python基础学习之如何对元组各个元素进行命名详解
2018/07/12 Python
python自定义时钟类、定时任务类
2021/02/22 Python
python GUI库图形界面开发之PyQt5单行文本框控件QLineEdit详细使用方法与实例
2020/02/27 Python
使用tensorflow实现VGG网络,训练mnist数据集方式
2020/05/26 Python
法拉利英国精品店:Ferraris Boutique UK
2019/07/20 全球购物
触摸春天教学反思
2014/02/03 职场文书
项目建议书范文
2014/05/12 职场文书
环保公益策划方案
2014/08/15 职场文书
招标承诺书
2014/08/30 职场文书
2014学习十八届四中全会精神思想汇报范文
2014/10/23 职场文书
2014年保险业务员工作总结
2014/12/23 职场文书
租车协议书
2015/01/27 职场文书
道歉情书大全
2015/05/12 职场文书
小学作文指导之如何写人?
2019/07/08 职场文书
Python Pandas知识点之缺失值处理详解
2021/05/11 Python