menu

JavaScript逻辑运算符“&&”和“||”短路原则的应用

逻辑运算符

在Javascript中,有逻辑运算符 与 &&, 或 ||, 非 !,常在条件句或循环中进行逻辑判断。

例如:

var a = 1, b = 1, c = 2;
if (a = b && (b = c || a != c)) 
{
	alert("true");
} else 
{
	alert("false");
}

括号中表达式值为,最后提示“true”。

短路原则

在逻辑运算中,这是一个通用的原则,这是由于表达式从左到右执行的特性,为了减少运算量而给运算器规定的操作。主要针对 &&|| 两种运算。

  • && 的判断是同真为真,一假为假,则运算如果左边的表达式值为 false,那么就不会再执行右边的表达式了,如果左表达式为 true,就会继续执行右表达式;

  • || 的判断是一真为真,同假为假,则运算如果坐表达式值为 true,那么就不用执行右边的表达式了,如果左表达式为 false,就会继续执行右表达式;

举例说明:

(1 == 1) && alert("msg1");
(1 != 1) && alert("msg2");
(1 == 1) || alert("msg3");
(1 != 1) || alert("msg4");

结果是提示“msg1”“msg4”。原理如上述。

因此,如果有以下表达式:

var a = 9;
if (a > 0) 
{
	alert("true");
} else 
{
	alert("false");
}

也许你会使用三目运算简化成这样:

var a = 9;
(a > 0) ? alert("true") : alert("false");

其实也可以这样写:

var a = 9;
(a > 0) && alert("true");
(a > 0) || alert("false");

Javascript中的应用

在javascript中,只有对象(Object)和布尔值true为真,其它例如 undefined, NaN, false 等,值为 false。为被定义的对象或未赋值变量也是 false,因为其值都是 undefined,这里就可以应用于检查某变量是否已定义

举例说明:

var a = 1;
var o = new Object();
var b;
a && alert("defined");       //已定义a,提示“defined”
o && alert("defined");       //已定义对象o,提示“defined”
Object && alert("defined");  //Object是一个已知的全局对象,提示“defined”
b || alert("not defined");   //b未赋值,提示“not defined”
p || alert("not defined");   //未定义p,提示“not defined”

除了这个也能衍生出其它相同原理的应用,类似于判断赋值 var a = (b > 0) && '9' 或判断定义变量 var abc = abc || "" 等。

js中使用这种方法可以减少代码量,提示性能,但同时也降低了代码可读性,比如个人觉得还是看以下代码比较舒适:

var a = 1;
if (a > 1)
{
	alert("true");
}

方法的选择就要视情况而权衡了。


技术文章推送

手机、电脑实用软件分享

微信搜索公众号: 程序骑士
wechat 微信公众号:程序骑士