Number有 整数 、浮点数值和Nan之分。编程
整数基本的数值字面量格式是十进制,还有八进制和十六进制编程语言
十进制能够直接输入:函数
var intNum=55;//整数
八进制第一位必须是0,而后是八进制数字序列(0~7),若是字面值的数值超出了范围,那么前导0将被忽略,后面的数值将被看成十进制数值解析。以下例子:spa
var octalNum1=070;//八进制的56 var octalNum2=079;//数值9在八进制中是无效的,所以会被解析为79 var octalNum3=08;//无效的八进制,会被解析为8
注意:八进制字面量在严格模式下面是无效的,会抛出错误!code
十六进制字面量的前两位必须是0x,后面跟任何的十六进制数字(0~9及A~F),字母能够大写或小写。以下例子:对象
var hexNum1=0xA;//十六进制的10 var hexNum2=0x1f;//十六进制的31
在进行计算时,全部的八进制和十六进制表示的数值最终都被转换成十进制数值。blog
浮点数值就是该数值中必须包含一个小数点,而且小数点后面必须只有一位数字。小数点前可没有数字,但不推荐。例如:ip
var floatNum1=1.1; var floatNum2=0.1; var floatNum3=.1;//不推荐
浮点数值对于极大或极小的数值,能够用e来表示(即科学计数法)。用e表示法表示的数值等于e前面的数值乘以10的指数次幂。例如:内存
var floatNum1=3.125e7;//等于31250000 var floatNum2=3.125e-7;//等于-31250000
浮点数值的最高精度是17位小数,但在计算的时候会有在特殊组合的计算方式上会有偏差,例如:字符串
0.1+0.2=0.30000000000000004;//并非0.3
因为内存限制,ECMAScript并不能保存世界上全部的数值。ECMAScript可以表示的最小数值保存在Number.MIN_VALUE中,这个值是5e-324;可以表示最大数值保存在Number.MAX_VALUE中,这个值是1.7976931348623157e+308。若是某次计算的结果获得了一个超出Javascript数值范围的值,那么这个数值将被自动转换成特殊的Infinity值。若是这个数值是负数,则会被转成-Infinity(负无穷),若是这个数值是正数,则会被转成Infinity(正无穷)。
函数isFinite()可检测是否超过范围,例:
var result=Number.MAX_VALUE+Number.MIN_VALUE; alert(isFinite(result));//true
NaN,非数值(Not a Number)是一个特殊的数值,这个数值用于表示一个原本要返回数值的操做数未返回数值的状况(这样就不会抛出错误了)。例如在其余的编程语言中,任何数值除以0都会致使错误,从而中止代码执行。可是在ECMAScript中,任何数值除以0会返回NaN,所以不会影响其余的代码执行。
NaN自己有两个非同寻常的特色。
首先,任何涉及NaN的操做(例:NaN/10)都会返回NaN,这个特色在多步计算中可能致使问题。
其次,NaN与任何值都不相等,包括NaN自己。例如:
alert(NaN==NaN);//fales
针对这两个特色,ECMAScript定义了isNaN()函数。这个函数接受一个参数,该参数能够是任何类型,而函数会帮咱们肯定这个参数是否“不是数值”。isNaN()在接收到一个值以后,会尝试将这个数值转换为数值。某些不是数值的值会直接转换为数值,例如字符窜“10”或Boolean值。而任何不能被转换为数值的值都会致使这个函数返回true。例如:
alert(isNaN(NaN));//true alert(isNaN(10));//false(10是一个数值) alert(isNaN("10"));//false(能够被转换成数值10) alert(isNaN("blue));//true alert(isNaN(true));//false(true能够转换成数值1)
有三个函数能够把非数值转换为数值:Number(),pareseInt()和pareseFloat()。
Number()能够用于任何数据类型。
而parseInt()和parseFloat()则专门用于把字符窜转换成数值。
Number()函数的转换规则以下:
•若是是Boolean值,true和false将分别被转换为1和0。
•若是是数字值,只是简单的穿任何返回。
•若是是null值,返回0。
•若是是undefined,返回NaN。
•若是是字符串,则遵循下列规则:
1.若是字符串中只包含数字(包括前面带正号或负号的状况),则将其转换为十进制数值,即“1”会变成1,“123”会变成123,而“011”会变成 11;
2.若是字符串中包含有效的浮点格式,如“1.1”,则将其转换为对应的浮点数值(一样,也会忽略前导);
3.若是字符串中包含有效的十六进制格式,例如“0xf”,则将其转换为相同大小的十进制整数数值;
4.若是字符串是空的(不包含任何数字),则将其转换为0;
•若是是对象,则调用对象的toString()方法,而后依照前面的规则转换返回额值。若是转换的结果是NaN,则对象的toString()方法,而后再次依照恰 面的规则转换返回的字符串值。
5.若是字符窜中包含除上述格式以外的字符,则将其转换为NaN。
根据规则看以下例子:
var num1=Number("hello word");//NaN var num2=Number("");//0 var num3=Number("0000011");//11 var num4=Number("ture");//1
parseInt()它会忽略字符串前面的空格,直到找到第一个个非空格字符。若是第一个字符不是数字字符或者负号,就会返回NaN。
parseInt()也可以识别出各类整数格式(十进制,八进制和十六进制)。就由于这样能够识,咱们应该给指定第二个参数指明是多少进制。例如:
var num1=parseInt("AF",16);//按十六进制解析,175 var num2=parseInt("10",2);//按二进制解析,2 var num3=parseInt("10",8);//按八进制解析,8 var num4=parseInt("10",10);//按十进制解析,10 var num5=parseInt("10",16);//按十六进制解析,16
parseFloat()与parseInt()函数相似,也是从第一个字符(位置0)开始解析每一个字符。并且也是一直解析到字符串末尾,或者解析到碰见一个无效的浮点数字字符为止。也就是说 ,字符串中的第一小数点是有效的,而第二个小数点就是无效的了,所以它后面的字符串将被忽略。例如:
alert(parseFloat("22.23.23"));//22.23
与parseInt()不一样的是它只解析十进制的值,所以它没有用第二个参数指定基础数的用法。
注意:若是字符串包含的是一个可解析为整数的数(没有小数点,或者小数点都是0),它会返回整数。
下面是使用parseFloat()转换数值的几个典型示例:
var num1=parseFloat("1234blue");//1234 var num2=parseFloat("0xA");//0 var num3=parseFloat("22.5");//22.5 var num4=parseFloat("22.34.5");//22.34 var num5=parseFloat("0908.5");//908.5 var num6=parseFloat("3.125e7");//31250000