第六章 数值的扩展

6.1 二进制和八进制表示法

ES6 提供了二进制和八进制数值的新的写法,分别用前缀0b(0B)0o(或0o)表示

0b11111101111 === 503  //true
0o767 === 503   //true

从ES5开始,在严格模式中,八进制就不再允许使用前缀0表示,ES6进一步明确,要使用前缀0o表示

如果要将0b0o前缀字符串值转为十进制,要使用Number方法

Number('0b111')   // 7

6.2 Number.isFinite(), Number.isNaN()

Number.isFinite() 用来检查一个数值是否为有限的

Number.isFinite(15) //true
Number.isFinite(0.8) //true
Number.isFinite(NaN) //false
Number.isFinite('foo') //false

Number.isNaN() 用来检查一个值是否为NaN

Number.isNaN(NaN) //true
Number.isNaN(15)  //false
Number.isNaN(9/NaN)  //true

它们和传统的全局方法isFinite()isNaN() 的区别在于,传统方法先调用Number()将非数值的值转为数值,再进行判断,而这两个新方法只对数值有效,非数值一律返回false

isFinite(25)    //true
isFinite('25')  //true
Number.isFinite(25)  //true
Number.isFinite('25')  //fasle

isNaN(NaN)  //true
isNaN('NaN') //true
Number.isNaN(NaN)  //true
Number.isNaN('NaN') //false

6.3 Number.parseInt(),Number.parseFloat()

ES6将全局方法parseInt()parseFloat(),移植到Number对象上,行为完全保持不变

这样做的目的,是逐步减少全局性方法,使得语言逐步模块化。

6.4 Number.isInteger()用来判断一个值是否为整数,需要注意的是,在JS内部,整数和浮点数是同样的储存方法,所以3和3.0被视为同一个值

Number.isInteger(25)  //true
Number.isInteger(25.0)  //true
Number.isInteger(25.1)  //false

6.5 Number.EPSILON

ES6在Number对象上面,新增一个极小的常量 Number.EPSILON

Number.EPSILON  //2.220446049250313e-16

引入一个这么小的量的目的,在于为浮点数计算,设置一个误差范围,我们知道浮点数计算是不准确的。

0.1 + 0.2   // 0.30000000000000004

如果这个误差能够小于 Number.EPSILON, 我们就可以认为得到了正确结果

0.30000000000000004 < Number.EPSILON  //false

因此 Number.EPSILON 的实质是一个可以接受的误差范围

function withinErrorMargin(left, right){
    return Math.abs(left - right) < Number.EPSILON;
}

withinErrorMargin(0.1+0.2,0.3)  //true

6.6 安全整数和Number.isSafeInteger()

JS能够准确表示的整数范围在 -2^532^53 之间(不含两个端点),超过这个范围,无法精确表示这个值。

Math.pow(2,53) //9007199254740992

9007199254740992 == 9007199254740993  //true

Math.pow(2,53) == Math.pow(2,53) + 1 //true

上面代码中,超过2的53次方后,一个数就不精确了。

所以,ES6引入了 Number.MAX_SAFE_INTEGERNumber.MIN_SAFE_INTEGER 这两个变量,用来表示这两个范围的上下限

Number.MAX_SAFE_INTEGER === Math.pow(2,53) -1 //true

Number.MIN_SAFE_INTEGER === -Number.MAX_SAFE_INTEGER //true

上面代码中,可以看到JS能够精确表示的极限

Number.isSafeInteger('a')  //false
Number.isSafeInteger(null)  //false
Number.isSafeInteger(3)   //true

这个函数实现的原理很简单:

Number.isSafeInteger = function(n){
   return ( typeof n === 'number' && Math.round(n) === n && 
   Number.MIN_SAFE_INTEGER <= n && n <= Number.MAX_SAFE_INTEGER);
}

实际使用这个函数时候,不要只验证运算结果,而要同时验证参与运算的每个值。

6.7 Math对象的扩展

ES6在Math对象上新增了17个与数学相关的方法。所有这些方法都是静态方法,只能在Math对象上调用。

(1) Math.trunc():用于去除一个数的小数部分,返回整数部分。

Math.trunc(4.1)  //4
Math.trunc(4.9)  //4
Math.trunc(-4.1)  //-4
Math.trunc(-4.9)  //-4
Math.trunc(-0.1234)  //-0

对于非数值,Math.trunc内部使用Number方法将其先转为数值

Math.trunc('4.9')  //4

对于空值和无法截取整数的值,返回NaN

Math.trunc('')  // NaN
Math.trunc('foo')  // NaN

实现原理:

Math.trunc = Math.trunc || function(x){
    return x < 0 ? Math.ceil(x) : Math.floor(x);
}

(2) Math.sign():用来判断一个数到底是正数、负数、还是零

会返回五种值:

正数:返回+1
负数:返回-1
0:返回0
-0:返回-0
其他值:返回NaN

实现原理:

Math.sign = Math.sign || function(x){
    x = +x;
    if( x === 0 || isNaN(x) ){
        return x;
    }
    return x > 0 ? 1 : -1;
}

(3) Math.cbrt():计算一个数的立方根

Math.cbrt(-1)  // -1
Math.cbrt(0)   // 0

对于非数值,先使用Number将其转为数值

实现原理:

Math.cbrt = Math.cbrt || function(x){
    var y = Math.pow(Math.abs(x), 1/3);
    return x < 0 ? -y : y;
}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容