Number.isSafeInteger

Number.isSafeInteger

Number.isSafeInteger()方法用来判断传入的参数值是否是一个“安全整数”(safe integer)。一个安全整数是一个符合下面条件的整数:

  • 可以准确地表示为IEEE-754双精度数字,

  • 其IEEE-754表示不能是对任何其他整数进行舍入以适应IEEE-754表示的结果。

比如,253 - 1 是一个安全整数,它能被精确表示,在任何 IEEE-754 舍入模式(rounding mode)下,没有其他整数舍入结果为该整数。作为对比,253 就不是一个安全整数,它能够使用 IEEE-754 表示,但是 253 + 1 不能使用 IEEE-754 直接表示,在就近舍入(round-to-nearest)和向零舍入中,会被舍入为 253

安全整数范围为 -(253 - 1)到253 - 1 之间的整数,包含 -(253 - 1)和253 - 1

语法

Number.isSafeInteger(testValue)

参数

testValue需要检测的参数。

返回值

一个布尔值表示给定的值是否是一个安全整数(safe integer)。

示例

Number.isSafeInteger(3 // true Number.isSafeInteger(Math.pow(2, 53) // false Number.isSafeInteger(Math.pow(2, 53) - 1 // true Number.isSafeInteger(NaN // false Number.isSafeInteger(Infinity // false Number.isSafeInteger('3' // false Number.isSafeInteger(3.1 // false Number.isSafeInteger(3.0 // true

Polyfill

Number.isSafeInteger = Number.isSafeInteger || function (value) { return Number.isInteger(value) && Math.abs(value) <= Number.MAX_SAFE_INTEGER; };

规范

SpecificationStatusComment
ECMAScript 2015 (6th Edition, ECMA-262)The definition of 'Number.isSafeInteger' in that specification.StandardInitial definition.
ECMAScript Latest Draft (ECMA-262)The definition of 'Number.isSafeInteger' in that specification.Living Standard

浏览器兼容性

FeatureChromeEdgeFirefoxInternet ExplorerOperaSafari
Basic Support(Yes)(Yes)32No(Yes)10

FeatureAndroidChrome for AndroidEdge mobileFirefox for AndroidIE mobileOpera AndroidiOS Safari
Basic Support(Yes)(Yes)(Yes)32No(Yes)(Yes)