js数值转换
有三个函数可以将非数值转换成数值:Number()
,parseInt()
,parseFloart()
。
Number()
Number()
是一个转型函数,可以用于任何数据类型,它的函数转换规则如下:
-
如果是Boolean值,true和false将分别被转换成1和0;
-
如果是数值,只是简单 的传入和返回;
-
如果是null值,返回0;
-
如果是undefined,返回NaN;
-
如果是字符串,遵循下列规则:
-
如果字符串中只包含数字(包括前面带正号或负号的情况),则将其转换为十进制数值,即“123”会变成123,而"011"会变成11(注意:前导的零被忽略了);
-
如果字符串中包含有效的浮点格式,如“1.1”,则将其转换为对应的浮点数值(同样,也会忽略前导零);
-
如果字符串中包含有效的十六进制格式,例如“oxf”,则将其转换为相同大小的十进制整数值;
-
如果字符串是空的(不包含任何字符),则将其转换为0;
-
如果字符串中包含除上述格式之外的字符,则将其转换为NaN;
-
如果是对象,则调用对象的valueOf()方法,然后依据前面的规则转换返回的值。如果转换的结果是NaN,则调用对象的toString()方法,然后再次依前面的规律转换返回的字符串值
案例如下:
var num1 = Number("Hello world!"); //NaN
var num2 = Number(" "); //0
var num3 = Number("000011"); //11
var num4 = Number(true); //1
parseInt(),parseFloat()
parseInt()
,parseFloart()
两个函数是专门用于把字符串转换成数值的。
parseInt()
是专门处理将字符串转换成整数的,该函数在转换字符串时,更多的是看其是否符合数值模型。
使用规则为:忽略字符串前面的空格,直至找到第一个非空格字符。
如果第一个字符不是数字字符或者负号,parseInt()
就会返回NaN;也就是说,用parseInt()
转换空字符串会返回NaN(Number()对空字符返回0)。
如果第一个字符是数字字符,parseInt()
会继续解析第二个字符,直到解析完所有后续字符或者遇到了一个非数字字符。例如,“1234blue”会被转换成1234,因为"blue"会被完全忽略;类似的,“22.5”或被转化成22,因为小数点并不是有效的数字字符。
如果字符串中第一个字符是数字字符,parseInt()
也能够识别出各种整数格式(即前面讨论的十进制,八进制和十六进制)
案例如下代码:
var num1 = parseInt(“1234blue”)`; //1234
var num2 = parseInt("")`; //NaN
var num3 = parseInt("oXA")`; //10(十六进制数)
var num4 = parseInt("22.5")`; //22
var num5 = parseInt(" 070"); //56(八进制)
var num6 = parseInt("70"); //70(十进制)
var num7 = parseInt(“oxf”); //15(十六进制)
parseInt()
还有两外一种用法,使用两个参数,第二个参数表示转换时使用的基数(即多少进制)。如果指定了16作为第二个参数,字符串可以不带前面的“ox”,具体案例如下:
var num1 = parseInt(“oxAF”,16)`; //175
var num2 = parseInt("AF",16)`; //175
var num3 = parseInt("AF")`; //NaN
var num4 = parseInt("10",2)`; //2(按二进制解析)
var num5 = parseInt("10",8); //8(按八进制解析)
var num6 = parseInt("10",10); //10(按十进制解析)
var num7 = parseInt(“10”,16); //16(按十六进制解析)
parseFloart()
与parseInt()
类似,也是从第一个字符(位置0)开始解析每个字符,而且一直解析到字符串末尾,或者解析到遇到一个无效的浮点数字字符为止,也就是说,字符串的第一个小数点是有效的,而第二个小数点就是无效的,因此它后面的字符串将被忽略。举例来说,“22.34.5”将会被转换为22.34.
parseFloart()
与parseInt()
的第二个区别是它始终都会忽略前导的零。parseFloart()
可以识别前面讨论的所有浮点数值格式,也包括十进制整数格式。但十六进制的字符串则始终会被转换为0,由于parseFloart()
只解析十进制,所以它没有用第二个参数指定基数的用法;最后注意一点:如果字符串包含的是一个可解析为整数的数(没有小数点,或者小数点后都是零),parseFloart()
会返回整数 。
案例如下:
var num1 = parseFloat(“1234blue”)`; //1234
var num2 = parseFloat("oxA")`; //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