加法(+)
加法(+
)运算符计算数字操作数或字符串连接的总和。
尝试一下
语法
js
x + y
描述
加法运算符(+
)为两种不同的运算重载:数字加法和字符串连接。在求值时,它首先将两个操作数强制转换为基本类型。然后,检查两个操作数的类型:
- 如果有一方是字符串,另一方则会被转换为字符串,并且它们连接起来。
- 如果双方都是 BigInt,则执行 BigInt 加法。如果一方是 BigInt 而另一方不是,会抛出
TypeError
。 - 否则,双方都会被转换为数字,执行数字加法。
字符串连接经常被认为等价于模板字符串或者 String.prototype.concat()
,但并非如此。加法强制将表达式转为基本类型,它优先调用 valueOf()
;另一方面,模板字符串和 concat()
则强制将表达式转为字符串,它们优先调用 toString()
。如果表达式有 [Symbol.toPrimitive]()
方法,字符串连接时会用 "default"
作为 hint
调用它,然而模板字符串则用 "string"
。这对于具有不同的字符串和原始值表现的对象来说很重要——例如 Temporal,它的 valueOf()
方法会抛出错误。
js
const t = Temporal.Now.instant();
"" + t; // 抛出 TypeError
`${t}`; // '2022-07-31T04:48:56.113918308Z'
"".concat(t); // '2022-07-31T04:48:56.113918308Z'
建议不要使用 "" + x
来执行字符串强制转换。
示例
数字加法
js
// Number + Number -> addition
1 + 2; // 3
// Boolean + Number -> addition
true + 1; // 2
// Boolean + Boolean -> addition
false + false; // 0
字符串连接
js
// String + String -> concatenation
"foo" + "bar"; // "foobar"
// Number + String -> concatenation
5 + "foo"; // "5foo"
// String + Boolean -> concatenation
"foo" + false; // "foofalse"
// String + Number -> concatenation
"2" + 2; // "22"
规范
Specification |
---|
ECMAScript Language Specification # sec-addition-operator-plus |
浏览器兼容性
BCD tables only load in the browser