ES6提供了二进制和八进制数值的新的写法,分别用前缀0b(或0B)和0o(或0O)表示。
0b11001000 === 200 // 二进制 0o310 === 200 // 八进制 0xc8 === 200 // 十六进制从ES5开始,在严格模式之中,八进制就不再允许使用前缀0表示,ES6 进一步明确,要使用前缀0o表示。
如果要将0b和0o前缀的字符串数值转为十进制,要使用Number方法。
Number('0b111') // 7 Number('0o10') // 8ES6在Number对象上,新提供了Number.isFinite()方法。用来检查一个数值是否为有限的finite,即不是Infinity。
Number.isFinite(15); // true Number.isFinite(0.8); // true Number.isFinite(NaN); // false Number.isFinite(Infinity); // false与传统的全局方法isFinite()的区别在于,传统方法先调用Number()将非数值的值转为数值,再进行判断,Number.isFinite()只对数值有效,对于非数值一律返回false。
isFinite(25) // true isFinite("25") // true Number.isFinite(25) // true Number.isFinite("25") // falseES6在Number对象上,新提供了Number.isNaN()方法。用来检查一个值是否为NaN。
Number.isNaN(NaN) // true Number.isNaN(15) // false Number.isNaN(9 / NaN) // true Number.isNaN('true' / 0) // true Number.isNaN('true' / 'true') // true与传统的全局方法isNaN()的区别在于,传统方法先调用Number()将非数值的值转为数值,再进行判断,Number.isNaN()只对数值有效,只有对于NaN才返回true,非NaN一律返回false。
isNaN(NaN) // true isNaN("NaN") // true Number.isNaN(NaN) // true Number.isNaN("NaN") // false Number.isNaN(1) // falseES6将全局方法parseInt(),移植到Number对象上面,行为完全保持不变。
// ES5的写法 parseInt('12.34') // 12 // ES6的写法 Number.parseInt('12.34') // 12 Number.parseInt === parseInt // trueES6将全局方法parseFloat(),移植到Number对象上面,行为完全保持不变。
// ES5的写法 parseFloat('123.45#') // 123.45 // ES6的写法 Number.parseFloat('123.45#') // 123.45 Number.parseFloat === parseFloat // true这样做的目的,是逐步减少全局性方法,使得语言逐步模块化。
用来判断一个数值是否为整数。
Number.isInteger(25) // true Number.isInteger(25.1) // falseJavaScript内部,整数和浮点数采用的是同样的储存方法,所以25和25.0被视为同一个值。
Number.isInteger(25) // true Number.isInteger(25.0) // true如果参数不是数值,Number.isInteger返回false。
由于JavaScript采用IEEE 754标准,数值存储为64位双精度格式,数值精度最多可以达到53个二进制位(1个隐藏位与52个有效位)。如果数值的精度超过这个限度,第54位及后面的位就会被丢弃,这种情况下,Number.isInteger可能会误判。
Number.isInteger(3.0000000000000002) // true