What is the difference between parseInt() and Number()?

前端 未结 10 801
無奈伤痛
無奈伤痛 2020-11-22 12:02

How do parseInt() and Number() behave differently when converting strings to numbers?

10条回答
  •  死守一世寂寞
    2020-11-22 12:37

    Summary:

    parseInt():

    • Takes a string as a first argument, the radix (An integer which is the base of a numeral system e.g. decimal 10 or binary 2) as a second argument
    • The function returns a integer number, if the first character cannot be converted to a number NaN will be returned.
    • If the parseInt() function encounters a non numerical value, it will cut off the rest of input string and only parse the part until the non numerical value.
    • If the radix is undefined or 0, JS will assume the following:
      • If the input string begins with "0x" or "0X", the radix is 16 (hexadecimal), the remainder of the string is parsed into a number.
      • If the input value begins with a 0 the radix can be either 8 (octal) or 10 (decimal). Which radix is chosen is depending on JS engine implementation. ES5 specifies that 10 should be used then. However, this is not supported by all browsers, therefore always specify radix if your numbers can begin with a 0.
      • If the input value begins with any number, the radix will be 10

    Number():

    • The Number() constructor can convert any argument input into a number. If the Number() constructor cannot convert the input into a number, NaN will be returned.
    • The Number() constructor can also handle hexadecimal number, they have to start with 0x.

    Example:

    console.log(parseInt('0xF', 16));  // 15
    
    // z is no number, it will only evaluate 0xF, therefore 15 is logged
    console.log(parseInt('0xFz123', 16));
    
    // because the radix is 10, A is considered a letter not a number (like in Hexadecimal)
    // Therefore, A will be cut off the string and 10 is logged
    console.log(parseInt('10A', 10));  // 10
    
    // first character isnot a number, therefore parseInt will return NaN
    console.log(parseInt('a1213', 10));
    
    
    console.log('\n');
    
    
    // start with 0X, therefore Number will interpret it as a hexadecimal value
    console.log(Number('0x11'));
    
    // Cannot be converted to a number, NaN will be returned, notice that
    // the number constructor will not cut off a non number part like parseInt does
    console.log(Number('123A'));
    
    // scientific notation is allowed
    console.log(Number('152e-1'));  // 15.21

提交回复
热议问题