一、区别
1. ?? 只有当左侧为null和undefined时,才会返回右侧的值,''或 0,都不会返回右侧默认值;
2. || 左侧为false的时候,就会返回右侧的值,不能排除''和0;
二、 ??和||符号的使用:
1、|| 的使用:如果第一个参数为true,则 || 返回第一个参数。否则,返回第二个参数。
- 符号前面的值为false,则返回后面的值(不论后面的值是true还是false)。例如:
const A = 0
const B = 5
const C = null
const valueA = A || B
console.log(valueA)
const valueB = C || B
console.log(valueB)
const valueC = A || C
console.log(valueC)
- || 符号前面的值为true,则返回前面的值。 例如:
const A = 5
const B = 3
const C = null
const valueA = A || B
console.log(valueA)
const valueB = B || C
console.log(valueB)
const valueC = A || C
console.log(valueC)
2、?? 的使用: 如果第一个参数不是 null/undefined,则 ?? 返回第一个参数。否则,返回第二个参数。
- ?? 符号前面的值为null/undefined,则返回后面的值。例如:
const A = undefined
const B = 5
const C = null
const valueA = A ?? B
console.log(valueA)
const valueB = C ?? B
console.log(valueB)
const valueC = A ?? C
console.log(valueC)
- ?? 符号前面的值为null/undefined,则返回前面的值。例如:
const A = 0
const B = 5
const C = ''
const valueA = A ?? B
console.log(valueA)
const valueB = B ?? C
console.log(valueB)
const valueC = C ?? B
console.log(valueC)