parseInt的使用,对于今天之前的我还是只使用用它来转换字符数字,但是今天我遇到下面三个表达式蒙圈了
所以我来解释一下 上面三个的结果(我采用对话方式分析) 我:console.log(parseInt(3,8)) 浏览器代码解析器:parseInt里面有两个参数,第一个参数是“值”,第二个参数是“进制”,八进制(0,1,2,3,4,5,6,7),示例认识3,所以返回值 3。 我:console.log(parseInt(3,2)) 浏览器代码解析器:parseInt里面有两个参数,第二个参数是二进制(0,1),额...,不好意思,我不认识3,返回NaN
我:console.log(parseInt(3,0))
浏览器代码解析器:parseInt里面有两个参数,第二个参数是零,额,好吧,应该是默认值十进制(0,1,2,3,4,5,6,7,8,9),嗯,很好我认识3,返回3
看到这里,我们就可以清楚了理解parseInt的使用了, 在上面那篇文章中作者提到了几个他不能理解的语法, console.log(parseInt(1/0,19)) //18 console.log(parseInt(false,16)) //250 console.log(parseInt(parseInt,16)) //15 console.log(parseInt('0x10')) //16 console.log(parseInt('10',2)) //2 看到这些既熟悉又陌生的代码,一开始也跟作者一样表示看不懂,但是我后面进行试验分析好最终解决了这几个问题,好的,马上进入我试验分析 我:console.log(parseInt(1/0,19)) 浏览器代码解析器:parseInt里面有两个参数,第二个参数是十九进制(0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f,g,h,i),额,1/0,好吧先运算 结果等于
我:console.log(parseInt(false,16)) 浏览器代码解析器:parseInt里面有两个参数,第二个参数是十六进制(0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f),额,false,是字符串(parseInt的世界里没有布尔值)==> 'false',
我:console.log(parseInt(parseInt,16)) 浏览器代码解析器:parseInt里面有两个参数,第二个参数是十六进制(0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f),额,parseInt,是我自己吗?不对,它后面没有(),它不是执行函数, 我:console.log(parseInt('0x10')) 浏览器代码解析器:parseInt里面只有一个参数,好的,采用默认的十进制(0,1,2,3,4,5,6,7,8,9), '0x',额,这个我认识,是十六进制的写法,好的,
我:console.log(parseInt('10',2)) 浏览器代码解析器:parseInt里面有两个参数,第二个参数是二进制(0,1),好的, '1'认识, '0'认识 ,嗯,返回二进制的10 转换成十进制等于2
好的,我的分析完毕。
现在总结一下,理解了parseInt中第二个参数 radix 是介于2-36的数, 计算机中 0到9为十进制,再往上十一进制开始用字母表示那么26个字母就可以再十进制上面加多26个进制, 即三十六进制。 原文章地址—— https://www.cnblogs.com/webBlog-gqs/p/8727677.html |
|