首頁 > web前端 > js教程 > 主體

js 字串轉換成數字的三種方法_javascript技巧

WBOY
發布: 2016-05-16 17:39:27
原創
1090 人瀏覽過

方法主要有三種

轉換函數、強制型別轉換、利用js變數弱型別轉換。

1. 轉換函數:

js提供了parseInt()和parseFloat()兩個轉換函數。前者把數值轉換成整數,後者則將數值轉換成浮點數。只有對String類型呼叫這些方法,這兩個函數才能正確運作;對其他類型回傳的都是NaN(Not a Number)。

一些例子如下:

複製程式碼 程式碼如下:

parseInt("12344hue"); 🎜>parseInt("0xA");   //returns   10
parseInt("22.5");   //returns   22
parseInt("blue")
parseInt()方法還有基底模式,可以把二進位、八進位、十六進位或其他任何進位的字串轉換成整數。基底是由parseInt()方法的第二個參數指定的,範例如下:

複製程式碼

程式碼如下:parseInt("AF",   16); 175parseInt("10",   2);   //returns   2
parseInt("10",   8);   //returns   8
par7("10 ); 🎜>


如果十進制數包含前導0,那麼最好採用基數10,這樣才不會意外地得到八進制的值。例如:

複製程式碼

程式碼如下:parseInt("010"); 🎜>parseInt("010",   8);   //returns   8parseInt("010",   10);   //returns   10

parseFloat()方法與parseInt()方法的處理方式相似。
使用parseFloat()方法的另一個不同之處在於,字串必須以十進位形式表示浮點數,parseFloat()沒有基底模式。

以下是使用parseFloat()方法的範例:


複製程式碼

程式碼如下:parseFloat("1234blue"). 🎜>parseFloat("0xA");   //returns   NaNparseFloat("22.5");   //returns   22.5parseFloat("22.34.55" "0908 ");   //returns   908parseFloat("blue");   //returns   NaN


2. 強制型別轉換

也可使用強制型別轉換(type casting)處理轉換值的型別。使用強制類型轉換可以存取特定的值,即使它是另一種類型的。
ECMAScript中可用的3種強制型別轉換如下:
Boolean(value)-把給定的值轉換成Boolean型別;
Number(value)-把給定的值轉換成數字(可以是整數或浮點數);
String(value)-把給定的值轉換成字串。 用這三個函數之一轉換值,將會建立一個新值,存放由原始值直接轉換成的值。這會造成意想不到的後果。

當要轉換的值是至少有一個字元的字串、非0數字或物件(下一節將討論這一點)時,Boolean()函數將傳回true。如果該值是空字串、數字0、undefined或null,它將傳回false。

可以用下面的程式碼段測試Boolean型的強制型別轉換。





複製程式碼

程式碼如下:

Boolean(""); 🎜>Boolean(""); Boolean("hi");   //true   –   non-empty   stringBoolean(100);   //true   –  Boolean(0);   //false   -   zeroBoolean(new   Object());   //true   –  object

Number()的強制型別轉換與parseInt()和parseFloat()方法的處理方式相似,只是它轉換的是整個值,而不是部分值。例如下:

複製碼 程式碼如下:

                   0
Number(true)                   1
Number(undefined)              NaN
Number(null)                   0
Number( "5.5 ")                5.5
Number( "56 ")                 56
Number( "5.6. 7 ")              NaN
Number(new        NaN
Number(new   Object())         0

最後一種強制型別轉換方法String()是最簡單的,範例如下:

複製程式碼 程式碼如下:
var   s1  "
var   oNull   =   null;
var   s2   =   oNull.toString();   //won't   work,  oNull.toString();   //won't   work,  oN ca
3. 利用js變數弱型別轉換
舉個小例子,一看,就會明白了。

複製程式碼

程式碼如下:<script></script>var  = '5012. ;
var   x   =   str-0;
x   =   x*1;




上例利用了js的弱型別的特點,只進行了算術運算,實現了字串到數字的型別轉換,不過這個方法還是不推薦的
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!