let arr = [10.18, 0, 10, 25, 23]
arr = arr.map(parseInt)
console.log(arr)
arr = arr.map((item, index) => {
// arr.map原本的意思:
// 循环遍历数组中的某一项就会触发回调函数
// 每一次还会传递当前项和当前项的索引
})
但是这道题map里不是我们自定义的匿名的回调函数了,
而是放的parseInt,所以parseInt现在是map循环时的回调函数。
parseInt也是个函数,比较常见的用法就是: parseInt('12px12') => 从左侧开始查找有效字符,遇到无效字符就停止查找=>12
(parseInt特点:括号里不管是什么值,都要转成字符串,从最左侧查找,遇到无效字符停止查找)
arr.map遍历第一项的时候就相当于把回调函数parseInt执行,并且传了两个参数item和index
arr.map会循环五次
parseInt('10.18', 0) => parseInt不识别小数点 => parseInt('10', 0),
parseInt('0', 1)
parseInt('10', 2)
parseInt('25', 3)
parseInt('23', 4)parseInt语法:parseInt([value],[radix])
->[radix]这个值是一个进制,不写或者写0都是按照10处理(特殊情况:如果value时以0X开头,则默认值是16而不是10)
->[radix]取值范围:2-36之间,如果不在这个之间,整个程序运行的结果一定是NaN
->parseInt([value],[radix]):意思是把[value]看作[radix]进制,然后转化为十进制-
如何把一个其他进制的值转为十进制呢?
举个例子:把147(八进制)转为十进制
这里有个位权值的概念:[位权值:每一位的权重,个位是0,十位十1,百位是2...]
计算规则:[value]的每一位 * [radix] ^ 位权值,然后把得到的值相加,
147的计算规则就是:1 * 8 ^ 2 + 4 * 8 ^ 1 + 7 * 8 ^ 0 = 64+32+7 = 103如果是带小数的该怎么计算呢?比如:12.23(四进制) => 十进制
小数点前的计算:1 * 4 ^ 1+2 * 4 ^ 0
小数点后的计算:小数点后的第一位位权值-1,第二位-2....
2 * 4 ^ -1 + 3 * 4 ^ -2
结果就是:1 * 4 ^ 1 + 2 * 4 ^ 0 + 2 * 4 ^ -1 + 3 * 4 ^ -2
这时有个问题:负次幂该怎么计算呢?
4^-1 = 1/4
4^-2 = 1/4 * 4
....
所以最终结果就是:4+2+0.5+0.1875 = 6.6875 -
找到规律和计算规则后开始计算正题:
parseInt('10.18', 0) =>从字符串左侧第一个字符开始查找,找到符合[radix]进制的值(遇到一个不合法的,则停止
查找),把找到的值变为数字,再按照把[radix]转为十进制的规则处理
[radix]如果是0或者不写,就默认为十进制,十进制的10转为十进制肯定还是10
parseInt('10', 0) => 10parseInt('0', 1) => 1不在2-36之间,所以运行结果是NaN
parseInt('10', 2)
把10看作二进制,最后转为10进制
1 * 2 ^ 1 + 0 * 2 ^ 0 = 2parseInt('25', 3)
5不是再三进制范围内=> parseInt('2', 3)
把2 当作3进制转为10进制
2 * 3 ^ 0 = 2parseInt('23', 4)
把23 当作4进制转为10进制
2 * 4 ^ 1+ 3 * 4 ^ 0 = 11所以console.log(arr) => [10, NaN, 2, 2, 11]
特殊:
parseInt(0023) // -> 19
按照我们刚才的逻辑讲,应该是23才对,可为什么结果是19呢?
是因为:
- 浏览器遇到0开始的数字,则认为是8进制
- 浏览器中我们看到的数字都是十进制的,所以默认就存在:把8进制转换为十进制的操作:
2 * 8 ^ 1 + 3 * 8 ^ 0 = 19
parseInt(19) -> 19
注意:再强调一下,这不是parseInt的功能,而是浏览器的
直接在浏览器中输出 0023,得到的也是19
扩展题目:
有99瓶水和1瓶毒药,老鼠喝了毒药7天后会死,(毒药和水可以被多只老鼠多次喝),问:七天后,最少消耗多少只老鼠可以区分出毒药?
答案:
用二进制给瓶编号, 是7位数, 用7只老鼠分别喝对应的位数为1的瓶子
七天后,例如1 4 5老鼠死了, 有毒的编号是 1001100