在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 相关文章推荐
下拉列表select 由左边框移动到右边示例
Dec 04 Javascript
jquery如何扑捉回车键触发的事件
Apr 24 Javascript
jquery实现简单文字提示效果
Dec 02 Javascript
JavaScript过滤字符串中的中文与空格方法汇总
Mar 07 Javascript
Bootstrap源码学习笔记之bootstrap进度条
Dec 24 Javascript
js原生Ajax的封装和原理详解
Mar 11 Javascript
微信小程序五星评分效果实现代码
Apr 06 Javascript
JS+canvas绘制的动态机械表动画效果
Sep 12 Javascript
基于openlayers4实现点的扩散效果
Aug 17 Javascript
Node.js实现mysql连接池使用事务自动回收连接的方法示例
Feb 03 Javascript
Vue+webpack项目基础配置教程
Feb 12 Javascript
JS简单判断是否在微信浏览器打开的方法示例
Jan 08 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
使用gd库实现php服务端图片裁剪和生成缩略图功能分享
2013/12/25 PHP
thinkphp3.2实现上传图片的控制器方法
2016/04/28 PHP
PHP实现简单计算器小程序
2020/08/28 PHP
Swoole扩展的6种模式深入详解
2021/03/04 PHP
Jquery获取元素的父容器对象示例代码
2014/02/10 Javascript
使用script的src实现跨域和类似ajax效果
2014/11/10 Javascript
下雪了 javascript实现雪花飞舞
2020/08/02 Javascript
javascript实现平滑无缝滚动
2020/08/09 Javascript
JavaScript的模块化开发框架Sea.js上手指南
2016/05/12 Javascript
js提交form表单,并传递参数的实现方法
2016/05/25 Javascript
Angular懒加载机制刷新后无法回退的快速解决方法
2016/08/30 Javascript
AngularJS自定义服务与fliter的混合使用
2016/11/24 Javascript
微信小程序开发之相册选择和拍照详解及实例代码
2017/02/22 Javascript
bootstrap动态添加面包屑(breadcrumb)及其响应事件的方法
2017/05/25 Javascript
JS判断数组那点事
2017/10/10 Javascript
浅谈vue中改elementUI默认样式引发的static与assets的区别
2018/02/03 Javascript
vue 路由页面之间实现用手指进行滑动的方法
2018/02/23 Javascript
解决nodejs的npm命令无反应的问题
2018/05/17 NodeJs
Bootstrap table中toolbar新增条件查询及refresh参数使用方法
2018/05/18 Javascript
微信小程序自定义导航栏
2018/12/31 Javascript
微信小程序动态添加view组件的实例代码
2019/05/23 Javascript
vue iview多张图片大图预览、缩放翻转
2019/07/13 Javascript
node.js使用net模块创建服务器和客户端示例【基于TCP协议】
2020/02/14 Javascript
通过实例解析chrome如何在mac环境中安装vue-devtools插件
2020/07/10 Javascript
Angular处理未可知异常错误的方法详解
2021/01/17 Javascript
Python使用cookielib模块操作cookie的实例教程
2016/07/12 Python
python中import学习备忘笔记
2017/01/24 Python
python将文本中的空格替换为换行的方法
2018/03/19 Python
利用css3画个同心圆示例代码
2017/07/03 HTML / CSS
html5关于外链嵌入页面通信问题(postMessage解决跨域通信)
2020/07/20 HTML / CSS
将n个数按输入顺序的逆序排列,用函数实现
2012/11/14 面试题
艺术设计专业个人求职信
2013/09/21 职场文书
倡议书作文
2015/01/19 职场文书
【HBU】数据库第四周 单表查询
2021/04/05 SQL Server
java设计模式--建造者模式详解
2021/07/21 Java/Android
深入理解CSS 中 transform matrix矩阵变换问题
2021/08/30 HTML / CSS