es6中??与||区别小结
??
和||
都是逻辑运算符,但它们的作用不同。??
是空值合并运算符,它用于检查左侧的表达式是否为null
或undefined
。如果是null
或undefined
,则返回右侧的表达式;如果不是,则返回左侧的表达式
let foo = null; let bar = foo ?? 'default'; // bar 的值为 'default' let baz; let qux = baz ?? 'default'; // qux 的值为 'default'
||
是逻辑或运算符,它用于检查左侧的表达式是否为假。如果左侧的表达式为假,则返回右侧的表达式;如果左侧的表达式为真,则返回左侧的表达式。在JavaScript中,只有null
、undefined
、''
、0
、NaN
被视为假值,其他值都被视为真值。
let foo = 'hello'; let bar = foo || 'default'; // bar 的值为 'hello' let baz; let qux = baz || 'default'; // qux 的值为 'default'
因此,??
和||
的区别在于它们的逻辑行为和使用场景。??
用于空值合并
,而||
用于逻辑或
。
?. 链判断运算符
左侧的对象是否为null或undefined,若是则不再往下运算,而是返回undefined,否则一直运算下去,直到返回最后一个值。
链判断运算符?.读取深度嵌套在对象链中的属性值,而不必验证每个值。当值为空时,表达式停止计算并返回 undefined。
let person = { name: '拾柒', body: { color: 'yellow', height: 179, weight: 70, sex: null }, action: function(name){ console.log(name) } } let res = person?.body?.age; // => undefined // 等价于 let res = person&& person.body&& person.body.location // 作用就是判断person下的body下的age是否为null或者undefined,当其中一链为null或者undefined时就直接返回undefined let res2 = person?.sex; // => undefined
链判断运算符?.有三种写法。
- obj?.prop // 对象属性是否存在(例子如上)
- obj?.[expr] // 同上
- func?.(...args) // 函数或对象方法是否存在
person ?. action ?. ('peter'); // peter
?? 空值合并运算符
忽略错误值(如 0 和空字符串)的同时指定默认值。
左侧的对象是否为 undefined 或 null,若是的话,直接返回下一个值,若不是的话,则直接返回前一个值。
判断方式和 || 一样
区别就是:
- ?? 只判断 undefined 和 null
function query(item) { return item ?? {} } // 等价于 function query(item) { if (item == null || item == undefined) { return {} } else { return item; } }
- || 判断假值 undefined、null、''、false、0
function query(item) { return item || {} } // 等价于 function query(item) { if (item === 0 || item === "" || item === false || item === null || item === undefined) { return {} } else { return item; } }
??= 空赋值运算符
仅当值为 null 或 undefined 时,此赋值运算符才会赋值(没想出来和??比有什么适用场景...)
function config(options) { options.duration ??= 100; options.speed ??= 25; return options; } config({ duration: 125 }); // { duration: 125, speed: 25 } config({}); // { duration: 100, speed: 25 }
&&= 与赋值运算符
当前者不是假值时,可赋值后者的值,若是假值时,直接赋值假值
let A = 'abc'; let a = 1; let b = 0; let c = false; let d = null; let e = undefined; let f = ''; A &&= '拾柒'; // '拾柒' a &&= '拾柒'; // '拾柒' b &&= '拾柒'; // 0 c &&= '拾柒'; // false d &&= '拾柒'; // null e &&= '拾柒'; // undefined f &&= '拾柒'; // ''
!! 双非
用来做类型判断,在第一步!(变量)之后再做逻辑取反运算
var a; if(a != null && typeof(a) != undefined && a != ''){ //a有内容才执行的代码 }
等价于
if(!!a){ //a有内容才执行的代码... }
到此这篇关于es6中??与||区别小结的文章就介绍到这了,更多相关es6 ??与||内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
微信小程序picker多列选择器(mode = multiSelector)
本文主要介绍了微信小程序picker多列选择器,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2021-07-07
最新评论