試一試
let a = 1;
let b = 0;
a &&= 2;
console.log(a);
// Expected output: 2
b &&= 2;
console.log(b);
// Expected output: 0
語法
js
x &&= y
描述
邏輯與賦值運算子會短路,這意味著 x &&= y 等價於 x && (x = y),不同之處在於表示式 x 只會被評估一次。
由於邏輯與運算子的短路特性,如果左運算元不是真值,則不會執行任何賦值。例如,即使 x 是 const,以下程式碼也不會丟擲錯誤:
js
const x = 0;
x &&= 2;
以下程式碼也不會觸發 setter
js
const x = {
get value() {
return 0;
},
set value(v) {
console.log("Setter called");
},
};
x.value &&= 2;
事實上,如果 x 不是真值,那麼 y 根本不會被評估。
js
const x = 0;
x &&= console.log("y evaluated");
// Logs nothing
示例
使用邏輯與賦值運算子
js
let x = 0;
let y = 1;
x &&= 0; // 0
x &&= 1; // 0
y &&= 1; // 1
y &&= 0; // 0
規範
| 規範 |
|---|
| ECMAScript® 2026 語言規範 # sec-assignment-operators |
瀏覽器相容性
載入中…