JS中的資料型別轉換:String轉換成Number的3種方法

weixin_33751566發表於2018-05-29
10136927-9564520def9b7161

今天有個學員問了個關於資料型別轉換的問題,我覺得這個是可以給大家說一下的。

JavaScript中,可以通過以下3種方法來將string值轉換成number:

1.呼叫Number()來對string進行值型別轉換。
2.parseInt()。
3.parseFloat()。

Number()

使用Number()函式來對string進行強制型別轉換是最直接的做法。不過,這種做法有一個侷限性:如果字串截去開頭和結尾的空白字元後,不是純數字字串,那麼最終返回結果為NaN。David Flanagan的JavaScript – The Definitive Guide 6th edition, 3.8.2節提到,用Number()函式來進行string-to-number轉換時,函式只接受10進位制字串,但測試結果表明事實並非如此,Number()函式可以接受”0xff”作為引數並將其轉換成數值255。

10136927-6bc1c0172475b840

parseInt()

parseInt()函式可以將字串轉換成一個整數,與Number()函式相比,parseInt()函式不僅可以解析純數字字串,也可以解析以數字開頭的部分數字字串(非數字部分字串在轉換過程中會被去除)。值得注意的是,當parseInt()函式所解析的是浮點數字符串時,取整操作所使用的方法為“向下取整”(truncate)。

除了字串作為第一個引數,parseInt()函式還可以接受2到36之間的任意整數作為第二個引數,用於指定轉換過程中的進位制數。

10136927-37a43a151b998003

parseFloat()

與parseInt()一樣,parseFloat()也可以解析以數字開頭的部分數字字串(非數字部分字串在轉換過程中會被去除)。與parseInt()不同的是,parseFloat()可以將字串轉換成浮點數;但同時,parseFloat()只接受一個引數,且僅能處理10進位制字串。

10136927-a707c361a0ce6724

所以我們平時方便使用,還是用parseInt() 比較多也比較好避免錯誤。

如果想學習更多前端開發教程,歡迎關注公眾號【前端研究所】,每天更新更多新內容哦!

10136927-f8d26b610287b6be.jpg

相關文章