js逻辑与或非

  • 首先js 会将 && 和 || 两边的值转成Boolean 类型,然后再进行逻辑关系运算 。

  • &&运算如果返回true,则取后面的值,如果 || 返回true,则取前面的值。

var num = 44 && 55;
var num2 = 44 || 55;
console.log(num);  // 55
console.log(num2);  // 44
  • 转换成boolean 的规则 :
    1. 对象、非零整数、非空字符串返回true
    2. 空字符串、null、undefined、NaN、false、0 ,返回false

短路原则:

var  a = "" || null || 3 ||  4;

相当于:
var a = false || false || true || true;

短路:第一个false,要去找下一个,第二个同是false,继续往下找。第三个是ture返回,不再检查第四。

结果为true  则返回第一个true,即是3
var b = 4 && 5 && null && 0;

相当于:
var b = true && true && false && false;

一个为假则为假。当找到第三个时为false,返回。

结果是false   则返回第一个false   即是null .

技巧:

  1. 检测是否定义,未定义则赋初始值。
// 判断一个变量是否存在,如果没有就给他一个初始值

var attr = attr || "";

function Foo(option) {
    var defaultValue = option || {};
}
Foo();
  1. 利用返回值的特性:
function getType(arg) {
    var num = (arg == 1 && '类型1') || (arg == 2 && '类型2') || 0;
    return num;
}
console.log(getType(1))

优化:
var num = {‘5’:1,’10’:2,’12’:3,’15’:4}[per] || 0;

function getValue(arg) {
    var num = {'5':1,'10':2,'12':3,'15':4}[arg] || 0;
    return num;
}
console.log(getType(5))
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值