This is the 25th day of my participation in the August Challenge
Type display conversion
Although JavaScript automatically performs many type conversions, there may be times when explicit conversions need to be performed.
The simplest way to perform an explicit conversion is to use the Boolean(), Number(), and String() functions:
Number("3") / / = > 3
String(false) // => "false": or use false.tostring ()
Boolean([]) // => true
Copy the code
Any value other than null or undefined has a toString() method, which usually returns the same result as the String() function.
Also, note that the Boolean(), Number(), and String() functions can also be called with new as constructors. If you use them this way, you get a “wrapper” object that behaves like a raw Boolean, number, or string value.
Some JavaScript operators perform implicit and sometimes explicit type conversions. If one of the operands of the + operator is a string, the other operand is converted to a string. The unary + operator converts its operand to a number. One more dollar! Operator converts its operand to a Boolean value and inverts it. These facts lead to the following type conversion idioms that you might see in some code:
x + "" // => String(x)
+x // => Number(x)
x-0 // => Number(x)!!!!! x// => Boolean(x): Boolean(x);
Copy the code
Formatting and parsing numbers is a common task in computer programs, and JavaScript has specialized functions and methods for more precise control of numeral-to-string and string-to-number conversions.
The toString() method defined by the Number class takes an optional argument that specifies the cardinality of the conversion. If no argument is specified, the conversion takes place in base 10. However, it is also possible to convert numbers from other cardinals (between 2 and 36). Such as:
let n = 17;
let binary = "0b" + n.toString(2); // binary == "0b10001"
let octal = "0o" + n.toString(8); // octal == "0o21"
let hex = "0x" + n.toString(16); // hex == "0x11"
Copy the code
When working with financial or scientific data, you might want to convert numbers to strings in order to control decimal or significant digits in the output, or you might want to control whether exponential notation is used. The Number class defines three methods for such numeric to string conversions. ToFixed () converts a number to a string with the specified number of digits after the decimal point. It never uses exponential notation. ToExponential () converts a number to a string using exponential representation with one digit reserved before the decimal point and a specified number of digits after the decimal point (which means that the significant number is one more than the specified value). ToPrecision () converts a number to a string with a specified number of significant digits. If the number of significant digits is not sufficient to display the whole integer part of the number, an exponential representation is used. Note that all three methods round the trailing numbers or fill them with zeros as needed. Consider the following example:
let n = 123456.789;
n.toFixed(0) / / = > "123457"
n.toFixed(2) / / = > "123456.79"
n.toFixed(5) / / = > "123456.78900"
n.toExponential(1) / / = > 1.2 e+5 ""
n.toExponential(3) / / = > 1.235 e+5 ""
n.toPrecision(4) / / = > 1.235 e+5 ""
n.toPrecision(7) / / = > "123456.8"
n.toPrecision(10) / / = > "123456.7890"
Copy the code
If you pass a string to the Number() conversion function, it will attempt to parse the string as an integer or floating-point text. This function only works with base 10 numbers and does not allow trailing characters that are not part of the number. The parseInt() and parseFloat() functions (these are global functions, not methods of any class) are more flexible. ParseInt () parses only integers, while parseFloat() parses both integers and floats. If a string begins with “0x” or “0x,” parseInt() interprets it as a hexadecimal number. Both parseInt() and parseFloat() skip leading whitespace, parse as many numeric characters as possible, and ignore anything that follows. If the first non-space character is not part of the valid numeric text, NaN is returned:
parseInt("3 blind mice") / / = > 3
parseFloat(" 3.14 meters") / / = > 3.14
parseInt("12.34") / / = > - 12
parseInt("0xFF") / / = > 255
parseInt("0xff") / / = > 255
parseInt("-0XFF") / / = > - 255
parseFloat("1") / / = > 0.1
parseInt("0.1") / / = > 0
parseInt("1") // => NaN: integers cannot start with a "."
parseFloat("$72.47") // => NaN: numbers cannot start with "$"
Copy the code
ParseInt () takes an optional second argument, specifying the cardinality (base) of the number to analyze. Valid values are between 2 and 36. Such as:
parseInt("11".2) // => 3: (1*2 + 1)
parseInt("ff".16) // => 255: (15*16 + 15)
parseInt("zz".36) // => 1295: (35*36 + 35)
parseInt("077".8) // => 63: (7*8 + 7)
parseInt("077".10) // => 77: (7*10 + 7)
Copy the code