史上最全javascript parseInt函数详解

时间:2021-11-20 18:22:59
全局 parseInt 函数的总结:
parseInt(numString, redix);
numString 将要被转换为Int的字符串。
 注意点: 
 1、可为数字或字符串, 不管怎样都会使用String(numString)将其转换成字符串; 如: parseInt(010); // 8  parseInt("010"); // 10
 2、如果numString前后有空格,那么将会忽略空格,如 " 23 ", 将会被解析成 "23";
 3、如果numString以数字开头,字母结尾,解析的时候则会从字母的地方终止,并返回已解析的数字。
redix 要转换的进制数,该值的范围是 2 - 36。
 注意点:
 一、如果用户指定了该值:
 不管指定的值是数字还是字符串,parseInt底层会使用Number对其进行转换,
 转换后得到的值为0或者NaN,都会忽略,仍使用默认值 10,否则判断是否是否位于 2-36中,如果不是则返回NaN。
 如 parseInt("31", 0)/parseInt("31", "aaa") 等价于 parseInt("31", 10)
 二、如果未指定该值:
 1、如果 numString 以0x开头,则该值的默认值是 16;
 2、如果 numString 以0开头,ECMAScript 3 环境该值默认为8,ECMAScript 5已经禁止这种做法,该值默认为10,所以视执行环境而定。
最佳实践: 使用parseInt时指定redix参数总是有必要的,代码可读性强,程序稳定。
parseInt("1", 0); // 1 等价于 parseInt("1", 10)
parseInt("1", "aaa"); // 1 等价于 parseInt("1", 10)
parseInt("2", 1); // NaN ,进制解析异常
parseInt("010"); // 8/10 视环境而定 String("010");// 8/10
parseInt(010); // 8   String(010);// 8
parseInt(0x10); // 16 String(0x10);// 16
parseInt("0x10"); // 16  (String("0x10");// "0x10" ) 等价于 parseInt("0x10", 16)// 16
parseInt(" 23 "); // 23
parseInt(" 23 abc"); // 23
parseInt(" 23abc "); // 23
["1", "2", "3"].map(parseInt); // ["1", NaN, NaN]