一尘不染

JavaScript中是否有“空合并”运算符?

javascript

Javascript中是否存在空合并运算符?

例如,在C#中,我可以这样做:

String someString = null;
var whatIWant = someString ?? "Cookies!";

我可以为Javascript找到的最佳近似是使用条件运算符:

var someString = null;
var whatIWant = someString ? someString : 'Cookies!';

这有点怪异恕我直言。我可以做得更好吗?


阅读 313

收藏
2020-04-25

共1个答案

一尘不染

更新资料

JavaScript现在支持无效的合并运算符(??)。当其左侧操作数为null或时undefined,它返回其右侧操作数,否则返回其左侧操作数。

使用前请检查兼容性。


与C#null合并运算符(??)等效的JavaScript 使用逻辑OR(||):

var whatIWant = someString || "Cookies!";

在某些情况下(以下已说明),该行为与C#的行为不匹配,但这是在JavaScript中分配默认/替代值的通用,简洁的方法。


Clarification

无论第一个操作数的类型如何,如果将其强制转换为Boolean都会导致false,赋值将使用第二个操作数。当心以下所有情况:

alert(Boolean(null)); // false
alert(Boolean(undefined)); // false
alert(Boolean(0)); // false
alert(Boolean("")); // false
alert(Boolean("false")); // true -- gotcha! :)

这表示:

var whatIWant = null || new ShinyObject(); // is a new shiny object
var whatIWant = undefined || "well defined"; // is "well defined"
var whatIWant = 0 || 42; // is 42
var whatIWant = "" || "a million bucks"; // is "a million bucks"
var whatIWant = "false" || "no way"; // is "false"
2020-04-25