3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Overview

null 合体演算子 ?? は、三項演算子? :と比較し以下の2点に違いがあります。

  • 無駄のない構文
  • null / undefined のみを判定条件とする

null 合体演算子 ?? とは

null 合体演算子 ?? は、null / undefined の値にデフォルト値をあてる演算子です。

ES2020で追加されました。

直感的な使い方

以下の例からわかるように、スマートかつ直感的な構文です。

const foo = null
const bar = undefined

console.log(foo ?? 'default') // 'default'
console.log(bar ?? 'default') // 'default'

三項演算子 ? : との違い

無駄のない構文

三項演算子では、同じ記述を繰り返す場合があります。

// foo を2度記述している
foo ? foo : 'falsy'

// 簡潔
foo ?? 'default'

0 / false / '' の扱い

null 合体演算子では、null / undefined に対しデフォルト値をあてます。
一方、三項演算子では falsy (0 / false / '' など) も false として扱います。

const foo = 0
const bar = false
const baz = ''

console.log(foo ?? 'default') // 0
console.log(bar ?? 'default') // false
console.log(baz ?? 'default') // ''

console.log(foo ? foo : 'falsy') // 'falsy'
console.log(bar ? bar : 'falsy') // 'falsy'
console.log(baz ? baz : 'falsy') // 'falsy'

??? : の役割は異なる

これまで見てきたように、??デフォルト値を扱う ことを目的としています。
? :falsy / truthy を扱う演算子であり、役割は異なります。

しかし、両者がオーバーラップしているのも事実です。

まとめなど

?? には以下の利点があると言えます。

  • 無駄がない構文
  • 0 / '' をそのまま扱える
  • falsyを扱わないことによる、隙のない実装

判定条件と返り値が同一

?? を使うことで、無駄のないコードになります。

// foo を2度記述している
const bar = foo ? foo : 'falsy'

// 簡潔
const bar = foo ?? 'default'

Object のプロパティ

三項演算子に加え、オプショナルチェイニングとも比較しました。
デフォルト値を簡潔に設定できます。

obj.title ??= 'Untitled'

// 冗長
obj.title = obj.title ? obj.title : 'Untitled'

// デフォルト値を設定できない
obj.title?

0 / '' をそのまま扱える

具体例が思いつきませんでした。
何かあれば教えてください。

3
2
4

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
3
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?