js parseInt的陷阱分析小結
更新時間:2011年03月05日 23:49:57 作者:
js parseInt的陷阱分析小結,當?shù)谝粋€字符為0時,Js會把它看成一個8進制數(shù)字,其他8進制之外的字符都回被忽略掉。
復制代碼 代碼如下:
var a = parseInt("09"), b = Number("09");
很多人會認為a和b的值都是數(shù)字9,但實際上不是。
parseInt的主要作用是把字符串轉換為整數(shù),或者把小數(shù)轉換為整數(shù)。一般情況下,我們只用到它的第一個參數(shù)。但實際上,它有兩個參數(shù):
parseInt(string, radix)
parseInt會根據(jù)radix指定的進制進行轉換,比如:
復制代碼 代碼如下:
alert(parseInt("10", 2)); // outputs '2'
在沒有指定radix或者radix為0的情況下,parseInt會按十進制進行轉換。然而,這在某些情況下有點特殊:
* 如果string的值以“0x”開頭,parseInt會按十六進制進行轉換;
* 如果string的值以“0”開頭,parseInt會按八進制進行轉換。
說回開頭的代碼,由于"09"是以“0”開頭,所以parseInt會按八進制進行轉換,但是“9”不是合法的八進制值(八進制只有0-7八個數(shù)字),所以轉換結果是0。
要避免這個陷進,可以強制指定radix:
復制代碼 代碼如下:
alert(parseInt("09", 10)); // outputs '9'
其它網友的補充:
看代碼:
復制代碼 代碼如下:
alert(parseInt(0.000001));
alert(parseInt(0.0000001));
第一條語句輸出 0, 第二條語句輸出 1, 囧。
繼續(xù)看代碼:
復制代碼 代碼如下:
alert(parseInt('0.000001'));
alert(parseInt('0.0000001'));
都輸出 0, 這才符合預期。
查看 ECMA-262 規(guī)范,parseInt 會先調用 toString 方法。問題已逐漸清晰:
復制代碼 代碼如下:
alert(0.000001);
alert(0.0000001);
第一條語句原樣輸出,第二條語句輸出 1e-7.
繼續(xù)翻查 ECMA-262 9.8.1 ToString Applied to the Number Type 一節(jié),恍然大悟:
復制代碼 代碼如下:
assertEquals("0.00001", (0.00001).toString());
assertEquals("0.000001", (0.000001).toString());
assertEquals("1e-7", (0.0000001).toString());
assertEquals("1.2e-7", (0.00000012).toString());
assertEquals("1.23e-7", (0.000000123).toString());
assertEquals("1e-8", (0.00000001).toString());
assertEquals("1.2e-8", (0.000000012).toString());
上面是 V8 引擎 number-tostring 的單元測試腳本, 很好地詮釋了 ECMA 規(guī)范。
小結:對于小于 1e-6 的數(shù)值來說,ToString 時會自動轉換為科學計數(shù)法。因此 parseInt 方法,在參數(shù)類型不確定時,最好封裝一層:
復制代碼 代碼如下:
function parseInt2(a) {
if(typeof a === 'number') {
return Math.floor(a);
}
return parseInt(a);
}
blueidea上面的文章:
去年11月做的一個東西,到今年 8,9 月突然出毛病了
調試了 1x 分鐘最后發(fā)現(xiàn)是 parseInt 的問題
MSDN 里的說明
Description
Converts strings into integers.
Syntax
parseInt(numstring, [radix])
The parseInt method syntax has these parts:
Part Description
[numstring] Required. A string to convert into a number.
[radix] Optional. A value between 2 and 36 indicating the base of the number contained in numstring. If not supplied, strings with a prefix of '0x' are considered hexidecimal and strings with a prefix of '0' are considered octal. All other strings are considered decimal.
用 parseInt 是在日期上的,比如 2005-10-08 用 正則解出 年月日 字符串,再用parseInt解出數(shù)字做他用。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
上面的看出不同了么?
"08"字符串被識別為8進制,parseInt("08") 出來的是 0,因為8進制是沒有8的
一般用parseInt也不會特意去寫后面的 radix,默認是 十進制
現(xiàn)在看來,大家還是 勤勞點,多寫個10,才保險啊
相關文章
JavaScript中動態(tài)向表格添加數(shù)據(jù)
本文給大家分享使用原生javascript實現(xiàn)動態(tài)向表格中添加數(shù)據(jù)的方法,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧2017-01-01JavaScript中三種for循環(huán)語句的使用總結(for、for...in、for...of)
這篇文章主要給大家介紹了關于JavaScript中三種for循環(huán)語句的使用的相關資料,For循環(huán)用在需要重復執(zhí)行的某些代碼,本文介紹的三種for循環(huán)分別包括for、for...in、for...of,需要的朋友可以參考下2021-06-06使用mock.js隨機數(shù)據(jù)和使用express輸出json接口的實現(xiàn)方法
這篇文章主要介紹了使用mock.js隨機數(shù)據(jù)和使用express輸出json接口的實現(xiàn)方法,需要的朋友可以參考下2018-01-01