JS魔法堂:再识Number type
Brief
本来只打算理解JS中0.1 + 0.2 == 0.30000000000000004的原因,但发现自己对计算机的数字表示和运算十分陌生,于是只好恶补一下。以下是恶补后的成果:
基础野:细说原码、反码和补码(http://www.cnblogs.com/fsjohnhuang/p/5060242.html)
基础野:细说无符号整数(http://www.cnblogs.com/fsjohnhuang/p/5078290.html)
基础野:细说有符号整数(http://www.cnblogs.com/fsjohnhuang/p/5082829.html)
基础野:细说浮点数(http://www.cnblogs.com/fsjohnhuang/p/5109766.html)
理解JS Number type背后的IEEE 754 64位双精度数值编码后,0.1 + 0.2 == 0.30000000000000004就不言而喻了,但单纯的理解了现象的本质是不够,我们需要的是如何解决这类问题,不然下次遇到同类问题我们只能同样的无力而已:(
但在寻求或自己手写工具库前,我觉得还是先了解JS为我们提供的原生API比较明智。
APIs
Numeric literal
ES5 APIs
OctalLiteral,八进制数值字面量,数值域以0开始且不含小数点。如:012转换为十进制数值为10 。
注意:在strict mode中OctalLiteral是非法的。
DecimalLiteral,十进制数值字面量,数值域以1-9或.或0.开始。
还有含指数和不含指数两种字面量形式
含指数形式:1.1e2表示110
e或E表示指数提示符,后面紧跟则指数值Exp;
Exp必须为正/负整数或零;
基数固定为10 。
HexLiteral,十六进制数值字面量,数值域以0x或0X开始。如:0x0F转换为十进制数值为15 。
ES6 APIs
BinaryLiteral, 二进制数值字面量,数值域以0b或0B开始。如:0b0100转换为十进制数值为4 。
OctalLiteral,八进制数值字面量,数值域以0o或0O开始。如:0o12转换为十进制数值为10 。
Number Function
当以Number([value])的方式调用时,返回值为Number value。
Number Constructor
当以new Number([value])的方式调用时,返回值为Number object。
Function Properties
ES5 APIs
Number.MIN_VALUE,可表示的最接近0的值。(2^53-1)*2^-1074 即约等于1.7976931348623157 × 10^308。
Number.MAX_VALUE,可表示的最大值。 (2^53-1)*2^971即约等于5 × 10^−324。
Number.NaN,返回Number type的Not-a-Number值。
Number.NEGATIVE_INFINITY,返回-Infinity。
Number.POSITIVE_INFINITY,返回Infinity。
window.isFinite([value]),判断value值是否为有限数。会先将value转换为Number value后再判断。
window.isNaN([value]),判断value值是否为Not-a-Number。会先将value转换为Number value后再判断。
window.parseInt([value], [radix=10]),以radix作为进制将value转换为十进制整数。
window.parseFloat([value]),将value转换为实数。
ES6 APIs
Number.MIN_SAFE_INTEGER,可精确表示的整数范围下限。-Math.pow(2, 53)+1,即是-9007199254740991。
Number.MAX_SAFE_INTEGER,可精确表示的整数范围上限。Math.pow(2, 53)-1,即是9007199254740991。
Number.EPSILON,极小值(2.220446049250313e-16),作为允许的误差范围使用。
(当某运算结果的误差小于Number.EPSILON则认为该结果是可被接受的)
判断是否可接受的函数:
function withinErrorMargin (left, right) {
return Math.abs(left - right) < Number.EPSILON
}
Number.isFinite([value]),判断value值是否为有限数。若value不为Number type则直接返回false。
Number.isNaN([value]),判断value值是否为Not-a-Number。若value不为Number type则直接返回false。
Number.parseInt([value], [radix=10]),以radix作为进制将value转换为十进制整数。
Number.parseFloat([value]),将value转换为实数。
Number.isInteger([value]),value为number类型,且小数部分全为0则返回true。(Number.isInteger(2.0)返回true)
Number.isSaveInteger([value]),value为number类型,且Number.MIN_SAFE_INTEGER <= value <= Number.MAX_SAFE_INTEGER则返回true。
Number.prototype Properties
ES5 APIs
Number.prototype.toString([radix=10]):DOMString,返回以radix作为进制输出数值字符串,radix为2~36。
注意:对于负数而言,当radix为2时返回的是不补码编码的位模式,而是形如 -10100.0101011 的 "负号" + "原码位模式" 的形式。
Number.prototype.valueOf():Number value,返回Number object的[[PrimitiveValue]]值。
Number.prototype.toFixed([fractionDigits=0]):DOMString,返回指定小数位的十进制定点数字符串。
注意:1.fractionDigits必须大于等于0和小于等于20,否则会抛RangeError;
2.若数值大于e21则直接返回Number.prototype.toString()的值;
3.若数值小于e21,则通过公式计算,所以和toString()的返回值不一定相同(两者均不精准)
().toString() === ""
().toFixed() === ""
().toString() === ""
().toFixed() === ""
Number.prototype.toPrecision([precision]):DOMString,返回指定精度的是十进制字数字符串。
注意:精度过高或过低都会引发数值的不精准。
(100.1).toPrecision() === "1e+2"
(100.1).toPrecision() === "100.09999999999999"
Number.prototype.toExponential(fractionDigits):DOMString,返回指定精度的是十进制字数科学计数法字符串
注意:精度过高或过低都会引发数值的不精准。
(100.1).toExponential() === "1.001e+2"
(100.1).toPrecision() === "1.0009999999999999e+2"
Consolusion
尊重原创,转载请注明来自:http://www.cnblogs.com/fsjohnhuang/p/5130876.html 肥子John^_^
Thanks
http://es6.ruanyifeng.com/#docs/number
http://es5.github.io/#x15.7.4.5
JS魔法堂:再识Number type的更多相关文章
- JS魔法堂:不完全国际化&本地化手册 之 实战篇
前言 最近加入到新项目组负责前端技术预研和选型,其中涉及到一个熟悉又陌生的需求--国际化&本地化.熟悉的是之前的项目也玩过,陌生的是之前的实现仅仅停留在"有"的阶段而已. ...
- JS魔法堂:jsDeferred源码剖析
一.前言 最近在研究Promises/A+规范及实现,而Promise/A+规范的制定则很大程度地参考了由日本geek cho45发起的jsDeferred项目(<JavaScript框架设计& ...
- JS魔法堂:属性、特性,傻傻分不清楚
一.前言 或许你和我一样都曾经被下面的代码所困扰 var el = document.getElementById('dummy'); el.hello = "test"; con ...
- JS魔法堂:追忆那些原始的选择器
一.前言 ...
- JS魔法堂:那些困扰你的DOM集合类型
一.前言 大家先看看下面的js,猜猜结果会怎样吧! 可选答案: ①. 获取id属性值为id的节点元素 ②. 抛namedItem is undefined的异常 var nodes = documen ...
- JS魔法堂:判断节点位置关系
一.前言 在polyfill querySelectorAll 和写弹出窗时都需要判断两个节点间的位置关系,通过jQuery我们可以轻松搞定,但原生JS呢?下面我将整理各种判断方法,以供日后查阅. 二 ...
- JS魔法堂:LINK元素深入详解
一.前言 我们一般使用方式为 <link type="text/css" rel="stylesheet" href="text.css&quo ...
- JS魔法堂:doctype我们应该了解的基础知识
一.前言 什么是doctype?其实我们一直使用,却很少停下来看清楚它到底是什么,对网页有什么作用.本篇将和大家一起探讨那个默默无闻的doctype吧! 二.什么是doctype doctype或DT ...
- JS魔法堂:浏览器模式和文档模式怎么玩?
一.前言 从IE8开始引入了文档兼容模式的概念,作为开发人员的我们可以在开发人员工具中通过“浏览器模式”和“文档模式”(IE11开始改为“浏览器模式”改成更贴切的“用户代理字符串”)品味一番,它的出现 ...
随机推荐
- 苹果全新 Mac OS X 系统开放下载
在今天的发布会上,苹果除了发布多款硬件产品之外,还更新了Mac OS X Mavericks(小牛)系统,作为重大改变,这一Mac系统将从今天起开始免费升级. 升级后的Mavericks系统将进一步与 ...
- 【Hello CC.NET】自动化发布时 Web.config 文件维护
在 <[Hello CC.NET]CC.NET 实现自动化集成> 的 HellowWorld 中经实现: 1.获取源码 2.编译项目 3.集成测试 4.Ftp发布项目 5.创建安装包 6. ...
- HTTP协议中POST、GET、HEAD、PUT等请求方法以及一些常见错误
(来源:http://www.tuicool.com/articles/Ermmmyn) HTTP请求方法: 常用方法: Get\Post\Head (1)Get方法. 取回请求URL标志的任何信息, ...
- ASP.NET 5系列教程 (一):领读新特性
近期微软发布了ASP.NET 5.0,本次发布的新特性需求源于大量用户的反馈和需求,例如灵活的跨平台运行时和自主部署能力使ASP.NET应用不再受限于IIS.Cloud-ready环境配置降低了云端部 ...
- [翻译]理解Ruby中的blocks,Procs和lambda
原文出处:Understanding Ruby Blocks, Procs and Lambdas blocks,Procs和lambda(在编程领域被称为闭包)是Ruby中很强大的特性,也是最容易引 ...
- Javascript定时器学习笔记
掌握定时器工作原理必知:JavaScript引擎是单线程运行的,浏览器无论在什么时候都只且只有一个线程在运行JavaScript程序. 常言道:setTimeout和setInterval是伪线程. ...
- EF架构~关于多对多关系表无法更新与插入的问题
回到目录 在EF里,我们设计模型时,会设计到多对多关系,在EF里会把这种关系会转成两个一对多的关系表,这是比较友好的,因为多对多来说,对于业务本身没什么意思,所以隐藏了,没什么坏处,但对于这个隐藏来说 ...
- sql基础知识:日期的常用用法
日期操作 select sysdate,add_months(sysdate,12) from dual; -- + 1 year select sysdate,add_months(sysdate, ...
- windows phone Datepicker Timepicker
选择程序包管理器控制台 在PM后输入Install-Package WPtoolkit可自动下载 PM> Install-Package WPtoolkit 在xaml中添加引用 xmlns:t ...
- javascript运算符——逻辑运算符
× 目录 [1]逻辑非 [2]逻辑与 [3]逻辑或 前面的话 逻辑运算符对操作数进行布尔运算,经常和关系运算符一样配合使用.逻辑运算符将多个关系表达式组合起来组成一个更复杂的表达式.逻辑运算符分为逻辑 ...