JavaScript逻辑运算符的使用技巧

前言

!, &&, || 三个运算符是JavaScript中重要的逻辑运算符,本文将介绍这三个运算符在JavaScript实际编程中的有趣使用技巧。

取反运算符(!)

如果对一个值连续做两次取反运算,等于将其转为对应的布尔值,与Boolean函数的作用相同。

!!x
// 等同于Boolean(x)

两次取反就是将一个值转为布尔值的简便写法。

var str='test';
var bl=!!str;
bl 
// true

Boolean(str)
// true

且运算符(&&)

且运算符的运算规则是:如果第一个运算子的布尔值为true,则返回第二个运算子的值(注意是值,不是布尔值);如果第一个运算子的布尔值为false,则直接返回第一个运算子的值,且不再对第二个运算子求值。

我们可以利用这个运算规则取代if结构,比如下面是一段if结构的代码,就可以用且运算符改写。

if (i) {
  doSomething();
}

// 等价于

i && doSomething();

这种跳过第二个运算子的机制,被称为“短路”。

或运算符(||)

或运算符的运算规则是:如果第一个运算子的布尔值为true,则返回第一个运算子的值,且不再对第二个运算子求值;如果第一个运算子的布尔值为false,则返回第二个运算子的值。

var x = 1;
true || (x = 2) // true
x // 1

短路规则对这个运算符也适用。

function saveText(text) {
  text = text || 'test';
  // ...
}

// 或者写成
saveText(this.text || 'test')

利用短路规则,或运算符可以为一个变量设置默认值。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值