一、Number():适用于所有类型
- 布尔类型,true和false将分别被转换成1和0。
- 数值类型,数值不变。
- null,返回值为0。
- undefined,返回值为NaN。
- 字符串
- 字符串只包含数值(包含正负号的情况),会转成对应的十进制。
- 字符串为有效的浮点类型(包含正负号的情况),则会转成对应的浮点类型。
- 字符串包含有效的十六进制格式,则会转成对应的十进制值。
- 字符串为空,转为0。
- 字符串为除了上的格式以外,则会转为NaN。
- 对象,则调用对象的valueOf()方法,然后会依照前面规则转换返回的值。如果转换的结果为NaN,则会调用toString()方法,然后再次依照前面的返回字符串的值。
输入:任意类型
输出:数字、NaN
二、parseInt():只能用于字符串
- 字符串为空,则返回为NaN。
- 字符串的第一个非空字符不是数字或正负号,则返回值为NaN。
- 字符串第一个有效字符为数字,继续解析,直至到一个非数字的字符。
- 字符串为‘0x’开头且后面为数字字符,则会转成十六制进行解析。
- 如果0开头且后面为数字 在ECMAScript3中当做八进制解析,但是在ECMAScript5中不支持。
- 支持使用基数的用法。parseInt(字符串,基数)
- 输入小数,去掉小数返回整数,不会四舍五入。
输入:字符串
输出:数字、NaN
按字符解析,直到遇见第一个非数字字符为止
注意:小数点也不是有效的数字字符。parseInt()方法还有基模式,可以把二进制、八进制、十六进制或其他任何进制的字符串转换成整数
三、parseFloat():只能用于字符串
- 字符串为空,则返回为NaN。
- 字符串的第一个非空字符不是数字或正负号,则返回值为NaN。
- 字符串第一个有效字符为数字,继续解析,直至到一个非数字的字符。
- 字符串中第一个小数点有效,之后的小数点则无效。
- 不能区分八进制和十六进制。
- 没有指定基数的用法。
输入:字符串
输出:数字、NaN
注意:字符解析,直到遇见一个无效的浮点数字字符为止。parseFloat() 只解析十进制