解析JS參數(shù)parseInt('012',?16)和parseInt(012,?16)是否相等
引言
parseInt('012', 16)和parseInt(012, 16)相等嗎?
["10", "10", "10", "10", "10"].map(parseInt)的結果是什么?
先來一起復習一下parseInt()
的基本用法。
一、parseInt()的使用說明
使用參數(shù)說明:paraseInt(value: string, radix?: number)
parseInt()是對Number()很好的補充
1.1 解析數(shù)字和字母的混合字符串
當Number()
返回的都是NaN
的時候,parseInt()
有不一樣的解析結果。parseInt會忽略無效字符,如果第一個字符串元素就非數(shù)字,那么就返回NaN
。
Number('123abc') // NaN Number('123asd1') // NaN Number('ad123') // NaN // ------- parseInt('123abc') // 123 parseInt('123asd1') // 123 parseInt('123---8979$$$') // 123 parseInt('ad123') // NaN
1.2 用于浮點數(shù)的取整:
console.log(parseInt(11.22)) // 11 console.log(Number(11.22)) // 11.22
1.3 將其他的進制轉化為十進制
- 標準格式:
parseInt(string, radix)
radix
: 表示字符串的基數(shù),取值范圍是從 2 到 36。16 就表示被解析值是十六進制數(shù)。- 計算方法:基數(shù) * (radix ^ (當前位數(shù) - 1)) 然后依次相加
如下例子:
console.log(parseInt(101, 2)) // 5 console.log(parseInt(123, 5)) // 38 parseInt('6axxx', 16) // 106
parseInt('6axxx', 16), 16進制能夠識別6a,到x為止。
其轉化的過程如下:
需要注意的是:
radix
的默認值不一定是10,如果字符串 string 以其它任何值開頭,則基數(shù)才是10 (十進制)。
這玩意兒很智能.輸入的如果是標準的16進制或者8進制的話,就可以把radix
初始化為對應的進制的值。比如說parseInt(0xfff)
的結果是4096,不用放入radix
值。
但是如果,你后面非要加非16進制的制位的話,那還是會按照對應的radix
來計算。比如parseInt(012, 3)
是3而不是8。
1.4 parseInt中的隱式轉化
parseInt('012', 16)和parseInt(012, 16)的結果是否一致呢?
我們打印結構如下:
前者是18,后者是16!, why?
很簡單,其實通過我這個小標題也能夠知道原因。因為parseInt(012, 16)發(fā)生了隱式轉化。第一參數(shù)是string
類型,而它是number
類型,構成了隱式轉化的條件,觸發(fā)了toString()
的規(guī)則。
012.toString()
結果為10.
所以說
parseInt(012, 16) = parseInt('10', 16).
1×(161)+0×(160)=161 \times(16^1)+0\times(16^0)=161×(161)+0×(160)=16
二、經典面試題
下面的輸出結果是什么?
["10", "10", "10", "10", "10"].map(parseInt);
我們需要有這么一個認知:
- map是一個函數(shù)
- map的的參數(shù)有兩個,一個函數(shù)
callbackFn
,一個可選對象thisArg
,用于執(zhí)行前者用作this
值。 - map的的參數(shù)函數(shù)有三個參數(shù):
currentValue
、index
、array
parseInt
就是一個函數(shù)
所以說,什么的題目等于下面代碼片段:
["10", "10", "10", "10", "10"].map((item, index) => { return parseInt(item, index) })
由此可得:
parseInt('10', 0) // 10 parseInt('10', 1) // NaN parseInt('10', 2) // 2 parseInt('10', 3) // 3 parseInt('10', 4) // 4
那么我們根據上面的描述,一起來討論[1, 2, 3, 4].map(parseInt)
的結果是什。
以上就是解析parseInt('012', 16)和parseInt(012, 16)是否相等的詳細內容,更多關于parseInt('012', 16) parseInt(012, 16)的資料請關注腳本之家其它相關文章!