javascript數值轉換

如下三個函數將非數值轉換爲數值:Number() 、parseInt()和 parseFloat()

Number()的轉換規則

  1. Boolean值 true會被轉換爲1 false會被轉換爲0函數

    var correct = true
    Number(correct)
    1
    var error = false
    Number(error)
    0
  2. 數字值 傳入什麼返回什麼code

    var sales = 10
    Number(sales)
    10
  3. null 值,返回 0對象

    var arg = null
    Number(arg)
    0
  4. undefined,返回 NaN字符串

    var vara = undefined
    Number(vara)
    NaN
  5. 字符串,遵循下列規則:二進制

    若是字符串中只包含數字(包括前面帶正號或負號的狀況),則將其轉換爲十進制數值,即"1"
    會變成 1,"123"會變成 123,而"011"會變成 11(注意:前導的零被忽略了)方法

    var str = '1'
    Number(str)
    1
    var str1 = '011'
    Number(str1)
    11
    var str2 = '+1'
    Number(str2)
    1
    var str3 = '-001'
    Number(str3)
    -1
    var str4 = '-121'
    Number(str4)
    -121

    若是字符串中包含有效的浮點格式,如"1.1",則將其轉換爲對應的浮點數值(一樣,也會忽
    略前導零)error

    var str = '1.1'
    Number(str)
    1.1
    var str1 = '+1.1'
    Number(str1)
    1.1
    var str2 = '-01.1'
    Number(str2)
    -1.1

    若是字符串中包含有效的十六進制格式,例如"0xf",則將其轉換爲相同大小的十進制整
    數值co

    若是字符串是空的(不包含任何字符),則將其轉換爲 0block

    var str = ''
    Number(str)
    0

    若是字符串中包含除上述格式以外的字符,則將其轉換爲 NaN字符

    var str = 'adfsfdsa'
    Number(str)
    NaN
  6. 若是是對象,則調用對象的 valueOf()方法,而後依照前面的規則轉換返回的值。若是轉換的結果是 NaN,則調用對象的 toString()方法,而後再次依照前面的規則轉換返回的字符串值

parseInt()轉換規則

因爲 Number()函數在轉換字符串時比較複雜並且不夠合理,所以在處理整數的時候更經常使用的是
parseInt()函數。parseInt()函數在轉換字符串時,更多的是看其是否符合數值模式。它會忽略字
符串前面的空格,直至找到第一個非空格字符。若是第一個字符不是數字字符,parseInt()
就會返回 NaN;也就是說,用 parseInt()轉換空字符串會返回 NaN(Number()對空字符返回 0)。如
果第一個字符是數字字符,parseInt()會繼續解析第二個字符,直到解析完全部後續字符或者遇到了
一個非數字字符。例如,"1234blue"會被轉換爲 1234,由於"blue"會被徹底忽略。相似地,"22.5"
會被轉換爲 22,由於小數點並非有效的數字字符。
指定基數會影響到轉換的輸出結果。例如:
var num1 = parseInt("10", 2); //2 (按二進制解析)
var num2 = parseInt("10", 8); //8 (按八進制解析)
var num3 = parseInt("10", 10); //10 (按十進制解析)
var num4 = parseInt("10", 16); //16 (按十六進制解析)
**多數狀況下,咱們要解析的都是十進制數值,所以始終將 10 做爲第二個參數是
很是必要的。**

parseFloat()轉換規則

與 parseInt()函數相似,parseFloat()也是從第一個字符(位置 0)開始解析每一個字符。並且
也是一直解析到字符串末尾,或者解析到碰見一個無效的浮點數字字符爲止。也就是說,字符串中的第
一個小數點是有效的,而第二個小數點就是無效的了,所以它後面的字符串將被忽略。舉例來講,
"22.34.5"將會被轉換爲 22.34。
除了第一個小數點有效以外,parseFloat()與 parseInt()的第二個區別在於它始終都會忽略前導
的零。parseFloat()能夠識別前面討論過的全部浮點數值格式,也包括十進制整數格式。但十六進制格
式的字符串則始終會被轉換成 0。因爲 parseFloat()只解析十進制值,所以它沒有用第二個參數指定基
數的用法。最後還要注意一點:若是字符串包含的是一個可解析爲整數的數(沒有小數點,或者小數點後
都是零),parseFloat()會返回整數。
var num1 = parseFloat("1234blue"); //1234 (整數)
var num2 = parseFloat("0xA"); //0 
var num3 = parseFloat("22.5"); //22.5 
var num4 = parseFloat("22.34.5"); //22.34 
var num5 = parseFloat("0908.5"); //908.5 
var num6 = parseFloat("3.125e7"); //31250000
相關文章
相關標籤/搜索