ES11中的bigint

ES11中的bigint

学习es11中的新语法。在js中,对整数类型的数据,存在着最大极限,这个极限就是

%title插图%num

const max = 2**53 // js幂运算
console.log(max) // 9007199254740992

同样,为了计算的准确性,js也定义了最大安全整数,这个整数是

console.log(Number.MAX_SAFE_INTEGER) // 9007199254740991

当我们的项目需要的数字很大的时候,会出现这样的乌龙事件

const max = 2**53 // js幂运算
console.log(max === max+1) //  true
const num = 9007199254740993
console.log(num) // 9007199254740992

为了解决这样的问题,es11中提出了一个新的基本类型,bigint。在使用的时候,可以有两种方法。

一、直接添加字母n,就像这样

const num = 9007199254740993n
console.log(num) // 9007199254740993n
console.log(typeof num)  // bigint

虽然是一种新的数据类型,但是有些“规矩”还是要遵守,比如

console.log(1n==1) // true 只要值相等,返回true
console.log(1n===1) // false 必须值和类型都相等,才返回false

二、小编理解的类似构造函数,就像这样

const num = BigInt(9007199254740993n)
console.log(num) // 9007199254740993n

同样,bigint类型也可以进行我们认知内的运算,就像这样

const num1 = BigInt(9007199254740993n)
const num2 = BigInt(9007199254740993n)
console.log(num1+num2) // 18014398509481986n

数据范围是扩大了,但是每次数字后面跟个n,看着总感觉怪怪的,为了达到视觉上的美感,我们可以将bigint转为字符串数据类型,就像这样

const num = BigInt(18014398509481986n)
console.log(num.toString()) // 18014398509481986

同样,我们需要转换成bigint的时候,通过BigInt再转换一次就可以了

const str = '18014398509481986'
console.log(BigInt(str)) // 18014398509481986n

 

分享到 :
相关推荐