Javascript中的&&操作符和三元表达式问题小结

最近使用操作符的过程中,发现逻辑判断的时候使用 || 和 && 操作符进行判断时,逻辑的严谨程度有问题,&& 操作符的 “短路”特性真是让人头疼,遇到这种情况我会先尝试使用括号的形式进行逻辑收缩控制,效果不是很理想,我最后都使用三元表达式来解决这个问题,不知道有没有对 && 操作符熟悉的小伙伴,请多多指点。

下面我列举几个例子来演示一下我平时的判断逻辑

在使用Vue的项目中需要根据值的判断显示某个元素

<div v-if="form.type == 1 && status == 1 || form.type > 1 || form.pics"></div>

其中type,status,pics变量来自Vuex中,页面中有操作status的commit方法,实际在修改完status后,值改变,但是页面没有隐藏对应的元素。

最后修改成了 三元表达式 解决了这个问题

<div v-if="form.type > 1 || form.pics || form.type == 1 ? ( status == 1 ? true : false ) : false "></div>

但是这样的表达式,比原来的简单逻辑判断变复杂了。代码不是很友好,不知道有没有更好的 && 判断解决这个问题。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值