JavaScript 基础(三):Number

基础系列文章:

JavaScript 基础(一):null 和 undefined

JavaScript 基础(二):String

JavaScript 基础(三):Number

JavaScript 基础(四):Array

JavaScript 基础(五):Object

JavaScript 基础(六):Map、Set

一、number、Number 区别

一般在使用的时候有以下这几种方法:

const num = 123
const num1 = Number(123)
const num2 = new Number(123)

其返回的结果有一定的差异,使用 typeof,=== 对比下

console.log(typeof num,typeof num1,typeof num2)    // number number object
console.log(num === num1)    // true
console.log(num === num2)    // false

可以看出:单独调用 Number 返回的也是一个数值;当 Number 和 new 一块使用,返回的是一个数值对象。

那么其本质的区别是:

number:原始值

Number:原始值包装类型,具有引用类型的特点,同时也具有对应原始类型的特殊行为。

number 本身是不具有方法的。但是我们为什么可以直接 . 出方法呢?

其实是编译器在后台做了工作,已经把 number 包装成了 Number 对象:

let num = 123
let num1 = num.toFixed(1)

// 等同于下面的三步
let num = new Number(123)   // 创建一个 Number 类型的实例
let num1 = num.toFixed(1)   // 调用实例上的方法
num = null                  // 销毁实例

这样就可以让原始值 string 拥有 String 对象的行为。

二、Number 基本用法

1、toString

直接返回数值的字符串形式。

2、toFixed

/**
 * 用法:返回指定小数位数的字符串
 *  toFixed(num)
 *    num:保留位数,小数点后几位
 */
console.log(num2.toFixed(2))    // 1263346567.00

3、toExponential

/**
 * 用法:返回数值的指数形式字符串
 *  toExponential(num)
 *    num:保留位数,小数点后几位
 */
console.log(num2.toExponential(2))  // 1.26e+9

4、toPrecision

/**
 * 用法:返回数值的指数形式字符串
 *  toPrecision(num)
 *    num:有效位数(小数点前后一共几位)
 */
console.log(num2.toPrecision(3))  // 1.26e+9

下面的几个都是 Number 上面的静态方法

5、parseFloat

/**
 * 用法:字符串转为浮点数
 *  Number.parseFloat(string)
 *    string:出去空格外,第一个字符是数值,否则为 NaN
 */
console.log(Number.parseFloat('123.45'))      // 123.45
console.log(Number.parseFloat('123.45##'))    // 123.45
console.log(Number.parseFloat('  123.45##'))  // 123.45
console.log(Number.parseFloat('ff123.45##'))  // NaN

6、parseInt

/**
 * 用法:字符串转换为整数,舍弃小数点后数值
 *  Number.parseInt(string)
 *    string:出去空格外,第一个字符是数值,否则为 NaN
 */
console.log(Number.parseInt('123.55'))      // 123
console.log(Number.parseInt('123.45##'))    // 123
console.log(Number.parseInt('  123.45##'))  // 123
console.log(Number.parseInt('ff123.45##'))  // NaN

7、isNaN

/**
 * 用法:判断是否是 NaN
 *  Number.isNaN(number)
 * 
 *  和全局的区别:
 *    Number.isNaN:只针对数值有效,不是数值的一律返回 false
 *    isNaN:对于非数值,调用 Number() 后判断
 */

console.log(Number.isNaN(NaN))          // true
console.log(Number.isNaN(15))           // false
console.log(Number.isNaN('15'))         // false
console.log(Number.isNaN(true))         // false
console.log(Number.isNaN(9/NaN))        // true
console.log(Number.isNaN('true' / 0))   // true
console.log(Number.isNaN('true' / 'true'))// true

// 和全局比较
console.log(isNaN(NaN))           // true
console.log(isNaN("NaN"))         // true
console.log(Number.isNaN(NaN))    // true
console.log(Number.isNaN("NaN"))  // false
console.log(Number.isNaN(1))      // false

8、isFinite

/**
 * 用法:是否是有限值,即不是 Infinity
 *  Number.isFinite(number)
 * 
 *  和全局的区别:
 *    Number.isFinite:只针对数值有效,不是数值的一律返回 false
 *    isFinite:对于非数值,调用 Number() 后判断
 */
console.log(Number.isFinite(15))        // true
console.log(Number.isFinite(0.8))       // true
console.log(Number.isFinite(NaN))       // false
console.log(Number.isFinite(Infinity))  // false
console.log(Number.isFinite(-Infinity)) // false
console.log(Number.isFinite('foo'))     // false
console.log(Number.isFinite('15'))      // false
console.log(Number.isFinite(true))      // false

// 和全局比较
console.log(isFinite(25))           // true
console.log(isFinite("25"))         // true
console.log(Number.isFinite(25))    // true
console.log(Number.isFinite("25"))  // false

9、isInteger

/**
 * 用法:判断是否是整数
 *  Number.isInteger(number)
 */

 console.log(Number.isInteger(10))    // true
 console.log(Number.isInteger(10.1))  // false

 // js 整数和浮点样的存储方法,所以下面的也是整数
 console.log(Number.isInteger(10.0))  // true

 // 不是数值的返回 false
 console.log(Number.isInteger(null))  // false
 console.log(Number.isInteger('17'))  // false
 console.log(Number.isInteger(true))  // false

 // 由于精度的问题,有些会被误判
 console.log(Number.isInteger(5.00000000000000002)) // true

 // 同样很接近 0 的也是,下面的 5 的 -325 次方
 console.log(Number.isInteger(5E-325))    // true

10、isSafeInteger

 /**
  * 用法:是否是安全的整数
  *   Number.isSafeInteger(number)
  *   
  *   因为精度的问题,超出一定的数值,即使是整数 js 表示也不准确
  *   所以在 ES6 中加入了 MIN_SAFE_INTEGER 和 MAX_SAFE_INTEGER 限定安全的整数范围
  */

console.log(Number.MAX_SAFE_INTEGER)  // 9007199254740991
console.log(Number.MIN_SAFE_INTEGER)  // -9007199254740991

// 下面两个表示一样了,因为超出了 MAX_SAFE_INTEGER
console.log(9007199254740992)  // 9007199254740992
console.log(9007199254740993)  // 9007199254740992

console.log(Number.isSafeInteger('a')) // false
console.log(Number.isSafeInteger(null)) // false
console.log(Number.isSafeInteger(NaN)) // false
console.log(Number.isSafeInteger(Infinity)) // false
console.log(Number.isSafeInteger(-Infinity)) // false

console.log(Number.isSafeInteger(3)) // true
console.log(Number.isSafeInteger(1.2)) // false
console.log(Number.isSafeInteger(9007199254740990)) // true
console.log(Number.isSafeInteger(9007199254740992)) // false)

console.log(Number.isSafeInteger(Number.MIN_SAFE_INTEGER - 1)) // false
console.log(Number.isSafeInteger(Number.MIN_SAFE_INTEGER)) // true
console.log(Number.isSafeInteger(Number.MAX_SAFE_INTEGER)) // true
console.log(Number.isSafeInteger(Number.MAX_SAFE_INTEGER + 1)) // false

三、Math 中处理 Number 的方法

之所以要放在这里,是认为这些方法算是对 Number 的一些补充。

下面主要介绍的就是这一类(Math 中方法很多,这里只介绍相关的)。

对于三角函数等的这些计算就没有包括在内。

/**
 * Math 中的一些数值操作
 */

// 绝对值 Math.abs
console.log(Math.abs(-2))               // 2

// 四舍五入取整 Math.round
console.log(Math.round(23.675))         // 24

// 向下取整 Math.floor
console.log(Math.floor(23.675))         // 23
console.log(Math.floor(-23.675))        // -24

// 取整 Math.trunc
// 和 floor 的区别:对于 负数的取整
console.log(Math.trunc(23.675))         // 23
console.log(Math.trunc(-23.675))        // -23

// 取最大值 Math.max
console.log(Math.max(2,34,5,6,23))      // 34

// 取最小值 Math.min
console.log(Math.max(2,34,5,6,23))      // 2

// 幂次方 Math.pow
console.log(Math.pow(2,3))              // 8

// 平方根 Math.sqrt
console.log(Math.sqrt(4))               // 16

// 立方根 Math.cbrt
console.log(Math.cbrt(123))             // 4.973189833268591
console.log(Math.cbrt(64))              // 4

// 随机数 0-1 之间 Math.random
console.log(Math.random())              // 随机的

 

posted @ 2020-12-10 16:33  漠里  阅读(476)  评论(0编辑  收藏  举报