JS数值转换函数:
- Number()
- parseInt()
- parseFloat()
Number()转换规则:
- 如果是Boolean,分别转化为0 , 1
- 如果是数字值,只是简单的传入和传出
- 如果是null值,返回0
- 如果是undefined, 返回NaN
- 如果是字符串,遵循以下规则:
- 如果字符串中只包含数字,(包括前面带正号或负号的情况),则将其转换为十进制数值,即"1"会变成 1,“123"会变成 123,而"011"会变成 11(注意:前导的零被忽略了);
- 如果字符串中包含有效的浮点格式,如"1.1”,则将其转换为对应的浮点(也会忽 略前导零)
- 如果字符串中包含有效的十六进制格式,例如"0xf",则将其转换为相同大小的十进制整 数值
- 如果字符串是空的(不包含任何字符),则将其转换为 0
- 如果字符串中包含除上述格式之外的字符,则将其转换为 NaN - 如果是对象,则调用对象的 valueOf()方法,然后依照前面的
- 规则转换返回的值。如果转换 的结果是 NaN,则调用对象的 toString()方法,然后再次依照前面的规则转换返回的字符串值
parseInt()转换规则:
parseInt()函数在转换字符串时,更多的是看其是否符合数值模式。它会忽略字符前面的空格,直到找到第一个非空格字符。
- 如果第一个字符不是数字字符或者负号,parseInt会返回NaN;也就是说,用parseInt()转换空格字符会返回NaN(Number()对空字符返回0)
- 如果第一个字符是数字字符parseInt()会继续解析第二个字符,直到解析完所有后续字符或者遇到了非数字字符。'1233aa’会被转换为1233.'22.3’会被转换为22,因为 . 不是有效的数字字符。
- 如果字符串中的第一个字符是数字字符,parseInt()也能够识别出各种整数格式。也就是说,如果字符串以’0x’开头并且后面跟数字字符,就会将其当做一个十六进制整数,如果字符串以’0’开头,并且后面跟数字字符,则会将其当做一个八进制数来解析。
var num1 = parseInt("1234blue"); // 1234
var num2 = parseInt(""); // NaN
var num3 = parseInt("0xA"); // 10(十六进制数)
var num4 = parseInt(22.5); // 22
var num5 = parseInt("070"); // 56(八进制数)
var num6 = parseInt("70"); // 70(十进制数)
var num7 = parseInt("0xf"); // 15(十六进制数)
ECMAScript 3 JavaScript引擎会把’070’当做八进制,而在ECMAScript 5 JavaScript引擎中,前导的0被忽略,当做十进制解析。
为了消除在使用parseInt()函数时可能导致的问题,可以为这个函数提供第二个参数:转换时使用的基数。
parseInt('10', 16)
parseInt('0xAF', 16)
//指定了十六进制可以不用写'ox'
parseInt('AF', 1 6)
parseFloat()转换规则
与parseInt()相同,parseFloat()也是从第一个字符开始解析每个字符。而且也是一直解析到字符串末尾,或者解析到遇见一个无效的浮点数字字符为止。也就是说,字符串的第一个小数点是有效的,第二个小数点就无效了。
parseFloat会忽略前导的0, 只解析十进制。
如果字符串包含的是一个可解析为整数的数(么有小数点或者小数点后面都是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