Unary plus (+)
The unary plus operator (+
) precedes its operand and evaluates to its
operand but attempts to convert it into a number, if it isn't already.
Syntax
+x
Description
Although unary negation (-
) also can convert non-numbers, unary plus is
the fastest and preferred way of converting something into a number, because it does not
perform any other operations on the number. It can convert string representations of
integers and floats, as well as the non-string values true
,
false
, and null
. Integers in both decimal and hexadecimal
(0x
-prefixed) formats are supported. Negative numbers are supported (though
not for hex). Using the operator on BigInt values throws a TypeError. If it cannot parse
a particular value, it will evaluate to NaN
.
Examples
Usage with numbers
const x = 1;
const y = -1;
console.log(+x);
// 1
console.log(+y);
// -1
Usage with non-numbers
+true // 1
+false // 0
+null // 0
+function(val){ return val } // NaN
+1n // throws TypeError: Cannot convert BigInt value to number
Specifications
Specification |
---|
ECMAScript Language Specification # sec-unary-plus-operator |
Browser compatibility
Report problems with this compatibility data on GitHubdesktop | mobile | server | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Unary plus ( + ) | ChromeFull support1 | EdgeFull support12 | FirefoxFull support1 | Internet ExplorerFull support3 | OperaFull support4 | SafariFull support1 | WebView AndroidFull support1 | Chrome AndroidFull support18 | Firefox for AndroidFull support4 | Opera AndroidFull support10.1 | Safari on iOSFull support1 | Samsung InternetFull support1.0 | DenoFull support1.0 | Node.jsFull support0.10.0 |
Legend
- Full support
- Full support
The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.