在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 相关文章推荐
AutoSave/自动存储功能实现
Mar 24 Javascript
JQuery EasyUI 日期控件如何控制日期选择区间
May 05 Javascript
JavaScript DOM进阶方法
Apr 13 Javascript
JQuery中DOM事件冒泡实例分析
Jun 13 Javascript
javascript实现别踩白块儿小游戏程序
Nov 22 Javascript
js实现一个简单的数字时钟效果
Mar 29 Javascript
详解如何用babel转换es6的class语法
Apr 03 Javascript
echarts整合多个类似option的方法实例
Jul 10 Javascript
Vuex中的State使用介绍
Jan 19 Javascript
vue路由导航守卫和请求拦截以及基于node的token认证的方法
Apr 07 Javascript
js中arguments对象的深入理解
May 14 Javascript
layer关闭弹出窗口触发表单提交问题的处理方法
Sep 25 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把大写命名转换成下划线分割命名
2015/04/27 PHP
PHP用mb_string函数库处理与windows相关中文字符及Win环境下开启PHP Mb_String方法
2015/11/11 PHP
php处理复杂xml数据示例
2016/07/11 PHP
Windows下wamp php单元测试工具PHPUnit安装及生成日志文件配置方法
2018/05/28 PHP
PHP dirname简单使用代码实例
2020/11/13 PHP
jQuery 使用个人心得
2009/02/26 Javascript
JavaScript 原型与继承说明
2010/06/09 Javascript
解决Jquery鼠标经过不停滑动的问题
2014/03/03 Javascript
javascript实现des解密加密全过程
2014/04/03 Javascript
javascript自定义的addClass()方法
2014/05/28 Javascript
用js判断是否为360浏览器的实现代码
2015/01/15 Javascript
教你用javascript实现随机标签云效果_附代码
2016/03/16 Javascript
解决jquery无法找到其他父级子集问题的方法
2016/05/10 Javascript
jQuery处理XML文件的几种方法
2016/06/14 Javascript
基于jquery实现多选下拉列表
2017/08/02 jQuery
js使用html2canvas实现屏幕截取的示例代码
2017/08/28 Javascript
JS基于设计模式中的单例模式(Singleton)实现封装对数据增删改查功能
2018/02/06 Javascript
Vue 应用中结合vux使用微信 jssdk的方法
2018/08/28 Javascript
vue2.x集成百度UEditor富文本编辑器的方法
2018/09/21 Javascript
ES6入门教程之Array.from()方法
2019/03/23 Javascript
微信小程序实现获取小程序码和二维码java接口开发
2019/03/29 Javascript
JS实现的对象去重功能示例
2019/06/04 Javascript
Angular+Ionic使用queryParams实现跳转页传值的方法
2020/09/05 Javascript
python连接远程ftp服务器并列出目录下文件的方法
2015/04/01 Python
python 简单搭建阻塞式单进程,多进程,多线程服务的实例
2017/11/01 Python
Python中pip更新和三方插件安装说明
2018/07/08 Python
Python实现的登录验证系统完整案例【基于搭建的MVC框架】
2019/04/12 Python
html5绘制时钟动画
2014/12/15 HTML / CSS
LN-CC美国:伦敦时尚生活的缩影
2019/02/19 全球购物
意大利香水和化妆品购物网站:Parfimo.it
2019/10/06 全球购物
公司合作意向书
2014/04/01 职场文书
公司的门卫岗位职责
2014/09/09 职场文书
MySQL创建高性能索引的全步骤
2021/05/02 MySQL
Mysql查询时间区间日期列表,不会由于数据表数据影响
2022/04/19 MySQL
阿里云 Windows server 2019 配置FTP
2022/04/28 Servers
如何用H5实现好玩的2048小游戏
2022/07/23 HTML / CSS