在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 24 Javascript
某页码显示的helper 少量调整,另附js版
Sep 12 Javascript
一个基于jQuery的树型插件(OrangeTree)使用介绍
May 03 Javascript
地址栏传递中文参数乱码在js里用escape转码
Aug 28 Javascript
使用CSS和jQuery模拟select并附提交后取得数据的代码
Oct 18 Javascript
jQuery 动态云标签插件
Nov 11 Javascript
js实现鼠标移到链接文字弹出一个提示层的方法
May 11 Javascript
简介JavaScript中的setDate()方法的使用
Jun 11 Javascript
javascript格式化日期时间方法汇总
Jun 19 Javascript
jQuery实现的超简单点赞效果实例分析
Dec 31 Javascript
js实现点击按钮弹出上传文件的窗口
Dec 23 Javascript
JS实现元素上下左右移动效果
Oct 18 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
linux下使用ThinkPHP需要注意大小写导致的问题
2011/08/02 PHP
CodeIgniter图像处理类的深入解析
2013/06/17 PHP
PHP 绘制网站登录首页图片验证码
2016/04/12 PHP
PHP 结合 Boostrap 结合 js 实现学生列表删除编辑及搜索功能
2019/05/21 PHP
JQuery 应用 JQuery.groupTable.js
2010/12/15 Javascript
web开发人员学习jQuery的6大理由及jQuery的优势介绍
2013/01/03 Javascript
利用jQuary实现文字浮动提示效果示例代码
2013/12/26 Javascript
浅析jQuery中调用ajax方法时在不同浏览器中遇到的问题
2014/06/11 Javascript
Javascript封装DOMContentLoaded事件实例
2014/06/12 Javascript
jQuery实现响应浏览器缩放大小并改变背景颜色
2014/10/31 Javascript
原生js实现的贪吃蛇网页版游戏完整实例
2015/05/18 Javascript
PHP+jQuery+Ajax+Mysql如何实现发表心情功能
2015/08/06 Javascript
JSONP跨域请求实例详解
2016/07/04 Javascript
用js实现简单算法的实例代码
2016/09/24 Javascript
详解react服务端渲染(同构)的方法
2017/09/21 Javascript
web前端vue之vuex单独一文件使用方式实例详解
2018/01/11 Javascript
基于openlayers4实现点的扩散效果
2020/08/17 Javascript
JS 使用 window对象的print方法实现分页打印功能
2018/05/16 Javascript
Vue渲染过程浅析
2019/03/14 Javascript
开发中常用的25个JavaScript单行代码(小结)
2019/06/28 Javascript
vue中使用element ui的弹窗与echarts之间的问题详解
2019/10/25 Javascript
es6 super关键字的理解与应用实例分析
2020/02/15 Javascript
[48:24]完美世界DOTA2联赛循环赛LBZS vs Forest 第一场 10月30日
2020/10/31 DOTA
用Python的Tornado框架结合memcached页面改善博客性能
2015/04/24 Python
学习python之编写简单乘法口诀表实现代码
2016/02/27 Python
Python3.4实现远程控制电脑开关机
2018/02/22 Python
解决python flask中config配置管理的问题
2019/07/26 Python
python实现简单成绩录入系统
2019/09/19 Python
python应用文件读取与登录注册功能
2019/09/23 Python
AVIS安飞士奥地利租车官网:提供奥地利、欧洲和全世界汽车租赁
2016/11/29 全球购物
财务管理专业毕业生求职信范文
2013/09/21 职场文书
图书馆标语
2014/06/19 职场文书
幼儿园感恩节活动方案
2014/10/06 职场文书
欢迎词范文
2015/01/27 职场文书
小学教师师德师风承诺书
2015/04/28 职场文书
千手观音观后感
2015/06/03 职场文书