js中逻辑与(&&)的短路操作特性
举个栗子更好理解:
在下面的代码块中,会出现报错的问题
var num1 = true;
var result = (num1 && num2);
console.log(result); //报错
但当我们将 num1 改成 false 时,像下面这样,就会输出 false
var num1 = true;
var result = (num1 && num2);
console.log(result); //false
在上面这个栗子中,只是改变了 num1 的真假值,就出现了完全不一样的结果,这就是由逻辑与的短路操作特性导致的:
这是我们很熟悉的一个表格,在这里可以发现,当第一个操作数为 false 时,最终的结果一定是 false
第一个操作数 | 第二个操作数 | 结果 |
---|---|---|
true | true | true |
true | false | false |
false | true | false |
false | false | false |
在前面的代码里,设定 num1 为 true 时,还不能决定最后的结果,因此要判断第二个操作数,但发现第二个操作数 num2 未声明,因此报错
但当设定 num1为 false 时,就已经可以确定最终的结果为 false,因此不会继续向第二个操作数检测,这就是短路操作