parseFloat()

  • parseFloat() 函数可解析一个字符串,并返回一个浮点数。
  • 该函数指定字符串中的首个字符是否是数字。如果是,则对字符串进行解析,直到到达数字的末端为止,然后以数字返回该数字,而不是作为字符串。
  • parseFloat会忽略前导的0, 只解析十进制。也就是说如果首位是0它会直接忽略掉首位的0向后面据徐解析
  • 如果字符串的第一个字符不能被转换为数字,那么 parseFloat() 会返回 NaN。

parseInt()

parseInt方法接收两个参数,parseInt(string,radix?);

1.基本用法,只接受一个参数,可以当做第二个参数默认是10。> parseInt的返回值只有两种可能,不是一个十进制整数,就是NaN。

a.将字符串转为整数。
parseInt('123'); // 123


b.如果字符串头部有空格,空格会被自动去除。
parseInt('  81'); // 81


c.如果parseInt的参数不是字符串,则会先转为字符串再转换。这个很重要。


d.字符串转为整数的时候,是一个个字符依次转换,如果遇到不能转为数字的字符,就不再进行下去,返回已经转好的部分。
parseInt('99aa'); // 99


e.如果字符串的第一个字符不能转化为数字(后面跟着数字的正负号除外),返回NaN。
parseInt('aa99'); // NaN
parseInt('-99'); // -99


f.如果字符串以0x或0X开头,parseInt会将其按照十六进制数解析。
parseInt('0x10'); // 16


g.如果字符串以0开头,将其按照10进制解析。
parseInt('011') // 11


h.如果参数以0开头,但不是字符串,则会先将数值转成字符串,然后解析,见规则c;
parseInt(011); // 9
// 解释一下,(011).toString()得到的结果是‘9’,具体原因请查看我的博文中有介绍toString方法


i.对于那些会自动转为科学计数法的数字,parseInt会将科学计数法的表示方法视为字符串,因此导致一些奇怪的结果。
parseInt(1000000000000000000000.5); // 1
// 等同于
parseInt('1e+21'); // 1
 
parseInt(0.0000008); // 8
// 等同于
parseInt('8e-7'); // 8

2.进制转换(接收两个参数),parseInt方法还可以接受第二个参数(2到36之间),表示被解析的值的进制,返回该值对应的十进制数。默认情况下,parseInt的第二个参数为10,即默认是十进制转十进制。

a.第一个参数解析规则参照第一条基本用法
b.如果第二个参数不是数值,会被自动转为一个整数。这个整数只有在2到36之间,才能得到有意义的结果,超出这个范围,则返回NaN。如果第二个参数是0、undefined和null,则直接忽略。

Q.E.D.


学而不厌 不耻下问