在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 学习笔记(八)javascript对象
Apr 12 Javascript
Mac/Windows下如何安装Node.js
Nov 22 Javascript
js加密解密字符串可自定义密码因子
May 13 Javascript
js动态往表格的td中添加图片并注册事件
Jun 12 Javascript
Bootstrap的基本应用要点浅析
Dec 19 Javascript
微信小程序--onShareAppMessage分享参数用处(页面分享)
Apr 18 Javascript
js中apply与call简单用法详解
Nov 06 Javascript
Vue.js与 ASP.NET Core 服务端渲染功能整合
Nov 16 Javascript
纯javascript实现选择框的全选与反选功能
Apr 08 Javascript
node.js使用fs读取文件出错的解决方案
Oct 23 Javascript
jsonp格式前端发送和后台接受写法的代码详解
Nov 07 Javascript
vue实现整屏滚动切换
Jun 29 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随机数生成代码与使用实例分析
2011/04/08 PHP
php实现四舍五入的方法小结
2015/03/03 PHP
PHP实现上一篇下一篇的方法实例总结
2016/09/22 PHP
jquery 将disabled的元素置为enabled的三种方法
2009/07/25 Javascript
从面试题学习Javascript 面向对象(创建对象)
2012/03/30 Javascript
jQuery动态设置form表单的enctype值(实现代码)
2013/07/04 Javascript
解析JavaScript中delete操作符不能删除的对象
2013/12/03 Javascript
js浏览器本地存储store.js介绍及应用
2014/05/13 Javascript
jquery中show()、hide()和toggle()用法实例
2015/01/15 Javascript
JavaScript数据类型学习笔记
2016/01/25 Javascript
AngularJS实现单独作用域内的数据操作
2016/09/05 Javascript
用jQuery实现可输入多选下拉组合框实例代码
2017/01/18 Javascript
jQuery插件FusionCharts绘制ScrollColumn2D图效果示例【附demo源码下载】
2017/03/22 jQuery
详解从angular-cli:1.0.0-beta.28.3升级到@angular/cli:1.0.0
2017/05/22 Javascript
解决html input验证只能输入数字,不能输入其他的问题
2017/07/21 Javascript
vue中实现先请求数据再渲染dom分享
2018/03/17 Javascript
配置eslint规范项目代码风格
2019/03/11 Javascript
[48:32]2018DOTA2亚洲邀请赛 3.31 小组赛 A组 LGD vs VG
2018/04/01 DOTA
[04:54]DOTA2-DPC中国联赛1月31日Recap集锦
2021/03/11 DOTA
python使用scrapy解析js示例
2014/01/23 Python
python 类对象和实例对象动态添加方法(分享)
2017/12/31 Python
在python中实现强制关闭线程的示例
2019/01/22 Python
Python 最强编辑器详细使用指南(PyCharm )
2019/09/16 Python
Python之指数与E记法的区别详解
2019/11/21 Python
如何通过命令行进入python
2020/07/06 Python
英国时尚家具、家居饰品及礼品商店:Graham & Green
2016/09/15 全球购物
琳达·法罗眼镜英国官网:Linda Farrow英国
2021/01/19 全球购物
用Python写一个for循环的例子
2016/07/19 面试题
毕业生优秀推荐信
2013/11/26 职场文书
2014年端午节活动方案
2014/03/11 职场文书
食品安全处置方案
2014/06/14 职场文书
中国梦团日活动总结
2014/07/07 职场文书
师德师风心得体会(2016精选篇)
2016/01/12 职场文书
2016学习医德医风心得体会
2016/01/25 职场文书
2016年学校禁毒宣传活动工作总结
2016/04/05 职场文书
使用feign服务调用添加Header参数
2021/06/23 Java/Android