此页面由社区从英文翻译而来。了解更多并加入 MDN Web Docs 社区。
加法(+)
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015年7月.
加法(+)运算符计算数字操作数或字符串连接的总和。
In this article
尝试一下
console.log(2 + 2);// Expected output: 4console.log(2 + true);// Expected output: 3console.log("hello " + "everyone");// Expected output: "hello everyone"console.log(2001 + ": A Space Odyssey");// Expected output: "2001: A Space Odyssey"语法
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 -> addition1 + 2; // 3// Boolean + Number -> additiontrue + 1; // 2// Boolean + Boolean -> additionfalse + false; // 0字符串连接
js
// String + String -> concatenation"foo" + "bar"; // "foobar"// Number + String -> concatenation5 + "foo"; // "5foo"// String + Boolean -> concatenation"foo" + false; // "foofalse"// String + Number -> concatenation"2" + 2; // "22"规范
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-addition-operator-plus> |