js中的||和&&的用法

与其他语言不同,在JS中,a&&b或者a||b返回的是要么是a,要么是b;而其他语言中返回的是true or false

对于js中的或与运算,需要隐式的转换为boolean类型再来运算;转换规则为:

a&&b

  如果a为true,则执行b并返回b的值;

  如果a为false,则返回false不执行b;

a||b

  如果a为true,则返回a的值不执行b;

  如果a为false,则执行b并返回b的值;

var a=3;  
var b="test";  
var c={name:'test'};  
var d={};  
  
a || b      // => 3  
c || b      // => {name:'test'}  
d || b      // => {}  
true || b      // => true  
false || b      // => 'test'  
NaN || b       // => 'test'  
'' || b           // => 'test'

a && b         // => 'test'  
c && b         // => 'test'  
d && b         // => 'test'  
true && b     // => 'test'  
false && b     // => fasle  
NaN && b     // => NaN  
'' && b         // =>''

 

转载于:https://www.cnblogs.com/lmjZone/p/8695803.html

在 JavaScript 中,`||`(逻辑或) `&&`(逻辑与)是常用的逻辑运算符,它们具有以下用法特性: ### `||`(逻辑或)运算符 - **用法**:用于判断多个条件中是否至少有一个为 `true`。如果第一个操作数为 `true`,则返回第一个操作数;否则返回第二个操作数。可以连续使用多个 `||` 运算符,只要其中一个条件为 `true`,整个表达式就为 `true`。 - **特性**:具有短路特性。即当第一个操作数为 `true` 时,不会再计算第二个操作数,因为无论第二个操作数是什么,整个表达式都已经确定为 `true`。 示例代码如下: ```javascript // 基本用法 let result1 = true || false; // 返回 true let result2 = false || true; // 返回 true let result3 = false || false; // 返回 false // 短路特性 function func1() { console.log('func1 被调用'); return false; } function func2() { console.log('func2 被调用'); return true; } let result = func1() || func2(); // 输出 "func1 被调用" "func2 被调用",返回 true ``` ### `&&`(逻辑与)运算符 - **用法**:用于判断多个条件是否都为 `true`。如果第一个操作数为 `false`,则返回第一个操作数;否则返回第二个操作数。可以连续使用多个 `&&` 运算符,只有当所有条件都为 `true` 时,整个表达式才为 `true`。 - **特性**:同样具有短路特性。即当第一个操作数为 `false` 时,不会再计算第二个操作数,因为无论第二个操作数是什么,整个表达式都已经确定为 `false`。 示例代码如下: ```javascript // 基本用法 let result4 = true && true; // 返回 true let result5 = true && false; // 返回 false let result6 = false && true; // 返回 false let result7 = false && false; // 返回 false // 短路特性 function func3() { console.log('func3 被调用'); return false; } function func4() { console.log('func4 被调用'); return true; } let result8 = func3() && func4(); // 输出 "func3 被调用",返回 false ``` ### 实际应用场景 - **默认值设置**:可以使用 `||` 运算符为变量设置默认值。 ```javascript let name = ''; let defaultName = 'Guest'; let finalName = name || defaultName; // 如果 name 为空字符串或 falsy 值,则使用 defaultName ``` - **条件执行**:使用 `&&` 运算符可以在某个条件满足时执行特定的代码。 ```javascript let isLoggedIn = true; isLoggedIn && console.log('用户已登录'); // 当 isLoggedIn 为 true 时,输出 "用户已登录" ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值