當前位置 主頁 > 服務器問題 > win服務器問題匯總 > 最大化 縮小

    js 字符串轉換成數字的三種方法

    欄目:win服務器問題匯總 時間:2019-11-22 01:05

    方法主要有三種

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

    1. 轉換函數:

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

    一些示例如下:

    復制代碼 代碼如下:
    parseInt("1234blue");   //returns   1234
    parseInt("0xA");   //returns   10
    parseInt("22.5");   //returns   22
    parseInt("blue");   //returns   NaN

    parseInt()方法還有基模式,可以把二進制、八進制、十六進制或其他任何進制的字符串轉換成整數。基是由parseInt()方法的第二個參數指定的,示例如下:

    復制代碼 代碼如下:
    parseInt("AF",   16);   //returns   175
    parseInt("10",   2);   //returns   2
    parseInt("10",   8);   //returns   8
    parseInt("10",   10);   //returns   10

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

    復制代碼 代碼如下:
    parseInt("010");   //returns   8
    parseInt("010",   8);   //returns   8
    parseInt("010",   10);   //returns   10

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

    下面是使用parseFloat()方法的示例:

    復制代碼 代碼如下:
    parseFloat("1234blue");   //returns   1234.0
    parseFloat("0xA");   //returns   NaN
    parseFloat("22.5");   //returns   22.5
    parseFloat("22.34.5");   //returns   22.34
    parseFloat("0908");   //returns   908
    parseFloat("blue");   //returns   NaN

    2. 強制類型轉換

    還可使用強制類型轉換(type casting)處理轉換值的類型。使用強制類型轉換可以訪問特定的值,即使它是另一種類型的。
    ECMAScript中可用的3種強制類型轉換如下:
    Boolean(value)——把給定的值轉換成Boolean型;
    Number(value)——把給定的值轉換成數字(可以是整數或浮點數);
    String(value)——把給定的值轉換成字符串。
    用這三個函數之一轉換值,將創建一個新值,存放由原始值直接轉換成的值。這會造成意想不到的后果。
    當要轉換的值是至少有一個字符的字符串、非0數字或對象(下一節將討論這一點)時,Boolean()函數將返回true。如果該值是空字符串、數字0、undefined或null,它將返回false。

    可以用下面的代碼段測試Boolean型的強制類型轉換。

    復制代碼 代碼如下:
    Boolean("");   //false   –   empty   string
    Boolean("hi");   //true   –   non-empty   string
    Boolean(100);   //true   –   non-zero   number
    Boolean(null);   //false   -   null
    Boolean(0);   //false   -   zero

777亚洲人成视频免费视频