JavaScript中判断整型的N种方法示例介绍
2019-12-10 16:00:33来源:爱站网 阅读 ()
在JavaScript开发的过程中,整数和浮点数是是有区别的,下文是爱站技术频道小编为大家带来的JavaScript中判断整型的N种方法示例介绍,希望对你学习有帮助。
整数类型(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中判断整型的N种方法示例介绍,希望本文的介绍能在操作中有所帮助,感谢大家一直以来的支持。
原文链接:https://js.aizhan.com/develop/JavaScript/10627.html
如有疑问请与原作者联系
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- javascript面向对象入门基础详细介绍 2020-03-29
- JavaScript函数表达式详解及实例 2020-03-25
- 如何用javascript连接access数据库 2020-03-20
- js中去掉字串左右空格 2020-03-20
- Javascript中的经典技巧 2020-03-20
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash