mirror of
https://github.com/ruanyf/es6tutorial.git
synced 2025-05-24 18:32:22 +00:00
add docs/number
This commit is contained in:
parent
5508f2dc64
commit
3026daa8e4
88
docs/number.md
Normal file
88
docs/number.md
Normal file
@ -0,0 +1,88 @@
|
||||
# 数值的扩展
|
||||
|
||||
## 二进制和八进制表示法
|
||||
|
||||
ES6提供了二进制和八进制数值的新的写法,分别用前缀0b和0o表示。
|
||||
|
||||
```javascript
|
||||
|
||||
0b111110111 === 503 // true
|
||||
0o767 === 503 // true
|
||||
|
||||
```
|
||||
|
||||
八进制用0o前缀表示的方法,将要取代已经在ES5中被逐步淘汰的加前缀0的写法。
|
||||
|
||||
## Number.isFinite(), Number.isNaN()
|
||||
|
||||
ES6在Number对象上,新提供了Number.isFinite()和Number.isNaN()两个方法,用来检查Infinite和NaN这两个特殊值。
|
||||
|
||||
它们与传统的isFinite()和isNaN()的区别在于,传统方法先调用Number()将非数值的值转为数值,再进行判断,而这两个新方法只对数值有效,非数值一律返回false。
|
||||
|
||||
```javascript
|
||||
|
||||
isFinite(25) // true
|
||||
isFinite("25") // true
|
||||
Number.isFinite(25) // true
|
||||
Number.isFinite("25") // false
|
||||
|
||||
isNaN(NaN) // true
|
||||
isNaN("NaN") // true
|
||||
Number.isNaN(NaN) // true
|
||||
Number.isNaN("NaN") // false
|
||||
|
||||
```
|
||||
|
||||
## Number.parseInt(), Number.parseFloat()
|
||||
|
||||
ES6将全局方法parseInt()和parseFloat(),移植到Number对象上面,行为完全保持不变。
|
||||
|
||||
这样做的目的,是逐步减少全局性方法,使得语言逐步模块化。
|
||||
|
||||
## Number.isInteger()和安全整数
|
||||
|
||||
Number.isInteger()用来判断一个值是否为整数。需要注意的是,在JavaScript内部,整数和浮点数是同样的储存方法,所以3和3.0被视为同一个值。
|
||||
|
||||
```javascript
|
||||
|
||||
Number.isInteger(25) // true
|
||||
Number.isInteger(25.0) // true
|
||||
Number.isInteger(25.1) // false
|
||||
|
||||
```
|
||||
|
||||
JavaScript能够准确表示的整数范围在-2ˆ53 and 2ˆ53之间。ES6引入了Number.MAX_SAFE_INTEGER和Number.MIN_SAFE_INTEGER这两个常量,用来表示这个范围的上下限。Number.isSafeInteger()则是用来判断一个整数是否落在这个范围之内。
|
||||
|
||||
```javascript
|
||||
|
||||
var inside = Number.MAX_SAFE_INTEGER;
|
||||
var outside = inside + 1;
|
||||
|
||||
Number.isInteger(inside) // true
|
||||
Number.isSafeInteger(inside) // true
|
||||
|
||||
Number.isInteger(outside) // true
|
||||
Number.isSafeInteger(outside) // false
|
||||
|
||||
```
|
||||
|
||||
## Math对象的扩展
|
||||
|
||||
ES6在Math对象上提供了更多的数学方法。
|
||||
|
||||
- Math.acosh(x) 返回x的反双曲余弦(inverse hyperbolic cosine)
|
||||
- Math.asinh(x) 返回x的反双曲正弦(inverse hyperbolic sine)
|
||||
- Math.atanh(x) 返回x的反双曲正切(inverse hyperbolic tangent)
|
||||
- Math.cbrt(x) 返回x的立方根
|
||||
- Math.clz32(x) 返回x的32位二进制整数表示形式的前导0的个数
|
||||
- Math.cosh(x) 返回x的双曲余弦(hyperbolic cosine)
|
||||
- Math.expm1(x) 返回eˆx - 1
|
||||
- Math.fround(x) 返回x的单精度浮点数形式
|
||||
- Math.hypot(...values) 返回所有参数的平方的和的平方根
|
||||
- Math.imul(x, y) 返回两个参数以32位整数形式相乘的结果
|
||||
- Math.log1p(x) 返回1 + x的自然对数
|
||||
- Math.log10(x) 返回以10为底的x的对数
|
||||
- Math.log2(x) 返回以2为底的x的对数
|
||||
- Math.sign(x) 如果x为负返回-1,x为0返回0,x为正返回1
|
||||
- Math.tanh(x) 返回x的双曲正切(hyperbolic tangent)
|
||||
- Math.trunc(x) 移除一个浮点数的小数位,返回一个整数
|
@ -221,16 +221,3 @@ var r = /hello\d/y;
|
||||
r.sticky // true
|
||||
|
||||
```
|
||||
|
||||
## 数值
|
||||
|
||||
### 二进制和八进制表示法
|
||||
|
||||
ES6提供了二进制和八进制数值的新的写法,分别用前缀0b和0o表示。
|
||||
|
||||
```javascript
|
||||
|
||||
0b111110111 === 503 // true
|
||||
0o767 === 503 // true
|
||||
|
||||
```
|
||||
|
@ -9,6 +9,7 @@
|
||||
- [ECMAScript 6简介](#docs/intro)
|
||||
- [let和const命令](#docs/let)
|
||||
- [字符串的扩展](#docs/string)
|
||||
- [数值的扩展](#docs/number)
|
||||
- [对象和函数的扩展](#docs/object)
|
||||
- [箭头函数](#docs/arrow)
|
||||
- [Iterator和for...of循环](#docs/iterator)
|
||||
|
Loading…
x
Reference in New Issue
Block a user