进制之间的转换
parseInt(string, radix)
定义:函数可解析一个字符串,并返回一个整数。
string - 必需。要被解析的字符串。
radix - 可选。表示要解析的数字的基数。该值介于 2 ~ 36 之间。
如果省略该参数或其值为 0,则数字将以 10 为基础来解析。如果它以 “0x” 或 “0X” 开头,将以 16 为基数。
如果该参数小于 2 或者大于 36,则 parseInt() 将返回 NaN。
举例,如果 string 以 "0x" 开头,parseInt() 会把 string 的其余部分解析为十六进制的整数。如果 string 以 0 开头,那么 ECMAScript v3 允许 parseInt() 的一个实现把其后的字符解析为八进制或十六进制的数字。如果 string 以 1 ~ 9 的数字开头,parseInt() 将把它解析为十进制的整数。
其它进制数 => 十进制
将目标进制数按从低位到高位(即从右往左)计算,第0位的权值是目标进制数的0次方,第1位的权值是目标进制数的1次方,第2位的权值是目标进制数的2次方,依次递增下去,把最后的结果相加的值就是十进制的值了。
十进制 => 其它进制数
除目标进制数取余法,即每次将整数部分除以目标进制数,余数为该位权上的数,而商继续除以目标进制数,余数又为上一个位权上的数,这个步骤一直持续下去,直到商为0为止,最后读数时候,从最后一个余数读起,一直到最前面的一个余数。
十六进制 => 十进制
十六进制用0123456789ABCDEF这16个数表示,逢16进1,A-F对应十进制10-15。
十六进制数:2AF5
计算过程:5*16^0 + 15*16^1 + 10*16^2 + 2*16^3
结果:10997
JavaScript可以用parseInt('2AF5', 16)
计算得到结果。
二进制 => 十进制
二进制用0和1表示,逢2进1。
二进制数:00101000
计算: 0*2^0 + 0*2^1 + 0*2^2 + 1*2^3 + 0*2^4 + 1*2^5 + 0*2^6 + 0*2^7
结果:40
JavaScript可以用parseInt('00101000', 2)
计算得到结果。
十进制 => 其他进制
十进制数998,转16进制 计算:
998/16=62.375,余数6
62/16=3.875,余数14,对应16进制的e
3/16=0.1875,余数3
结果:3e6
JavaScript可以使用原生方法toString()
进行转换
let value = 998
value.toString(2) // 二进制
value.toString(16) // 十六进制
value.toString(8) // 八进制
也可以自己实现一个10进制转2-8进制的函数:
function mulBase (num, base) {
const s = []
let result = ''
do {
// 取余数并将其压入栈
s.push(num % base)
// 取商,并对值向下舍入,去除小数位
num = Math.floor(num /= base)
} while (num > 0) // 当数大于0则执行
while (s.length > 0) {
result += s.pop()
}
return result
}
mulBase(998, 2) // '1111100110'
不同进制互转
可以使用parseInt
先将目标进制转成十进制,再使用toString
转换成对应进制
// 十六进制转八进制
let value = '3e6'
parseInt(value, 16).toString(8) // 1746
// 八进制转二进制
let value = '1746'
parseInt(value, 8).toString(2) // 1111100110