在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 自定义事件初探
Aug 21 Javascript
JavaScript 拾漏补遗
Dec 27 Javascript
客户端 使用XML DOM加载json数据的方法
Sep 28 Javascript
30个让人兴奋的视差滚动(Parallax Scrolling)效果网站
Mar 04 Javascript
jquery 插件学习(二)
Aug 06 Javascript
单击某一段文字改写文本颜色
Jun 06 Javascript
react脚手架如何配置less和ant按需加载的方法步骤
Nov 28 Javascript
详解vue组件中使用路由方法
Feb 12 Javascript
vue 表单之通过v-model绑定单选按钮radio
May 13 Javascript
产制造追溯系统之通过微信小程序实现移动端报表平台
Jun 03 Javascript
微信公众号平台接口开发 获取access_token过程解析
Aug 14 Javascript
layui表格分页 记录勾选的实例
Sep 02 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读取Excel内的图片(phpspreadsheet和PHPExcel扩展库)
2019/11/19 PHP
Javascript 强制类型转换函数
2009/05/17 Javascript
纯CSS打造的导航菜单(附jquery版)
2010/08/07 Javascript
DIY jquery plugin - tabs标签切换实现代码
2010/12/11 Javascript
Lazy Load 延迟加载图片的jQuery插件中文使用文档
2012/10/18 Javascript
JavaScript实现维吉尼亚(Vigenere)密码算法实例
2013/11/22 Javascript
javascript 弹出的窗口返回值给父窗口具体实现
2013/11/23 Javascript
异步动态加载JS并运行(示例代码)
2013/12/13 Javascript
详解JavaScript基于面向对象之继承实例
2015/12/16 Javascript
jQuery实现判断控件是否显示的方法
2017/01/11 Javascript
Nodejs 发送Post请求功能(发短信验证码例子)
2017/02/09 NodeJs
React Native 真机断点调试+跨域资源加载出错问题的解决方法
2018/01/18 Javascript
jquery根据name取得select选中的值实例(超简单)
2018/01/25 jQuery
JS动画实现回调地狱promise的实例代码详解
2018/11/08 Javascript
浅谈JS和jQuery的区别
2019/03/27 jQuery
js实现简单分页导航栏效果
2019/06/28 Javascript
[00:34]DOTA2上海特级锦标赛 VG战队宣传片
2016/03/04 DOTA
Python通过websocket与js客户端通信示例分析
2014/06/25 Python
Python中的左斜杠、右斜杠(正斜杠和反斜杠)
2016/08/30 Python
在 Python 应用中使用 MongoDB的方法
2017/01/05 Python
windows下安装python的C扩展编译环境(解决Unable to find vcvarsall.bat)
2018/02/21 Python
PyCharm配置mongo插件的方法
2018/11/30 Python
对python:threading.Thread类的使用方法详解
2019/01/31 Python
Python学习笔记之For循环用法详解
2019/08/14 Python
Golang GBK转UTF-8的例子
2019/08/26 Python
Python爬虫实现“盗取”微信好友信息的方法分析
2019/09/16 Python
python 图片二值化处理(处理后为纯黑白的图片)
2019/11/01 Python
英国票务网站:Ticketmaster英国
2018/08/27 全球购物
三星英国官网:Samsung英国
2018/09/25 全球购物
优秀员工自荐书范文
2013/12/08 职场文书
学生励志演讲稿
2014/01/06 职场文书
2015年十一国庆节演讲稿
2015/03/20 职场文书
奖励通知
2015/04/22 职场文书
数据结构课程设计心得体会
2016/01/15 职场文书
员工升职自我评价
2019/03/26 职场文书
六种css3实现的边框过渡效果
2021/04/22 HTML / CSS