萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> js中parseInt函數

js中parseInt函數

 從很熱門的實例parseInt("09")==0說起。
parseInt(number,type)這個函數後面如果不跟第2個參數來表示進制的話,默認是10進制。
比如說parseInt("010",10)就是10進制的結果:10,
parseInt("010",2)就是2進制的結果:2,
parseInt("010",8)就是8進制的結果:8,
parseInt("010",16)就是2進制的結果:16。

下面我來說說沒有指定進制單位的時候,默認是10進制,但:如果是裡面的Number是0開頭的就認為是8進制的,如果是0x開頭的就認為是16進制的。
parseInt("10")==>parseInt("010",10)===>10parseInt("010")==>parseInt("010",8)==>8parseInt("0x10")==>parseInt("010",16)==>16.

到這裡很順利.
許多事情不是想的那麼順利,比如說如果Number不是我們給的正常數字又怎麼解釋呢。查了些資料,是這樣說的:
parseInt(Number)如果中間的Number遇到不是數字(0-9)的就中斷往下解析,就只取不是數字之前的值去運算:比如parseInt("100x"),就相當於parseInt("100")===》parseInt("100",10)==>100,又如parseInt("0100x")===>parseInt("0100")===>parseInt("100",8)===>64.
到這裡我們似乎無視了一個就是16進制中的有個x,它也不是數字,是不是遇到x也無視了呢。嘗試下了發現在這個特殊處理了下,
比如parseInt("0x10")===>parseInt("10",16)===>16和最上面的結果相符,但卻和我剛說的,不是字符就自動不解析就應該理解成parseInt("0")相違背。

這裡就需要注意下,parseInt裡面的Number是這樣的,當如果第一個不是0且不是字符就認為是10進制,一切照舊執行,遇到字母就停下來。又當如果是第一個是0,後面那個就需要注意了,如果是x就繼續往下走,這裡的x不代表數值,只能和前面的0一起組成0x代表16進制的單位,後面的才按上面我們講的遇到非數字停止解析的規則來。比如parseInt("0xt")==>parseInt("0x")==>parseInt("",16)就是NaN了。

總結下,parseInt(Number)裡面的值:如果是第一位不是0就遇到字母就停止解析,並把字母前面的值作為10進制去解析,如果第一個就是字母那麼值就是空,空成了NaN,
比如:parseInt("a")==>parseInt("",10)==>NaN.parseInt("10a")==>parseInt("10")==>parseInt("10",10)==>10;
如果第一位是0,且第2位不是x也和上面一樣遇到字母就停止解析,並把字母前面的值作為8進制去解析,比如:parseInt("0a")==>parseInt("0")==>parseInt("0",10)==>0.PS:這個有點特殊,因為0a被解析成了0,還不具備看做是8進制的結構,下面那個就明顯了。
parseInt("010a")==>parseInt("010")==>parseInt("10",8)==>8;如果第一位是0,且第2位是x那後面也和上面一樣遇到字母就停止解析,並把字母前面的值作為16進制去解析,比如:parseInt("0xt")==>parseInt("",16)==>NaN.parseInt("0x12t")==>parseInt("12",16)==>18.

copyright © 萬盛學電腦網 all rights reserved