JavaScript中逻辑或(||)逻辑与(&&)

在JavaScript中,||(逻辑或)和&&(逻辑与)是逻辑运算符,它们用于根据操作数的值来返回布尔值或执行短路求值(short-circuit evaluation)。

逻辑或(||

  • 如果第一个操作数的值为真(true),则返回第一个操作数的值,并且不会评估第二个操作数(短路求值)。
  • 如果第一个操作数的值为假(false),则返回第二个操作数的值。

在JavaScript中,以下值被认为是false的:

  • false
  • 0
  • ""(空字符串)
  • null
  • undefined
  • NaN

其余所有的值都被认为是true的。

示例:

复制代码
let a = 0;  
let b = "Hello";  
let c = a || b; // c 的值为 "Hello",因为 a 是 false 的  
  
// 短路求值示例  
function getValue(obj) {  
    return obj.value || 'default';  
}  
  
let obj = { value: 'custom' };  
console.log(getValue(obj)); // 输出 "custom"  
  
obj = {};  
console.log(getValue(obj)); // 输出 "default",因为 obj.value 是 undefined,即 false

逻辑与(&&

  • 如果第一个操作数的值为真(true),则返回第二个操作数的值,并且会评估第二个操作数(短路求值)。
  • 如果第一个操作数的值为假(false),则返回第一个操作数的值,并且不会评估第二个操作数(短路求值)。

示例:

复制代码
let a = true;  
let b = "World";  
let c = a && b; // c 的值为 "World",因为 a 是 true 的  
  
// 短路求值示例  
function checkAndLog(obj) {  
    if (obj && obj.name) {  
        console.log(obj.name);  
    }  
}  
  
let person = { name: 'Alice' };  
checkAndLog(person); // 输出 "Alice"  
  
checkAndLog(null); // 不输出任何内容,因为 null 是 false 的,短路求值导致不会执行 console.log

注意点

由于||&&在JavaScript中存在短路求值的特性,它们不仅可以用作逻辑运算符,还可以用于变量赋值和条件判断时的代码简化。但是,这种用法有时可能会导致代码的可读性降低,因此在团队项目中使用时需要谨慎。

相关推荐
Alair‎11 分钟前
Vue 3 基础教程:从入门到精通
前端·javascript·vue.js
百锦再11 分钟前
树形数据展示:树形表格与树形控件的深度对比(Vue实现)
javascript·vue.js·ecmascript·递归·tree·data·table
Sylvia33.13 分钟前
体育数据API实战:用火星数据实现NBA赛事实时比分与状态同步
java·linux·开发语言·前端·python
码农阿豪13 分钟前
Vue+Ant Design表格组件开发实战:从问题到优化的完整指南
前端·javascript·vue.js
百锦再17 分钟前
Vue不是万能的:前后端不分离开发的优势
前端·javascript·vue.js·前端框架·vue
一天拉了7遍18 分钟前
安利一款超实用的前端可视化打印设计器:Vue Print Designer
前端·javascript·vue.js
遗憾随她而去.20 分钟前
js 插件 Clipboard.js 与原生 Clipboard API 全方位对比
开发语言·前端·javascript
人道领域20 分钟前
Day | 07 【苍穹外卖 :用户端添加购物车】
java·开发语言·数据库·后端·苍穹外卖
kyriewen20 分钟前
作用域与作用域链:JS 的“找东西”逻辑,闭包到底是个啥?
前端·javascript·ecmascript 6
不像程序员的程序媛20 分钟前
springboot对于@PathVariable自动解码问题
java·前端·javascript