“||”的使用:
在javascript以及许多语言中,||(逻辑或)运算符,作用是:对两个表达式取或运算
result = expression1 || expression2
如果expression1与expression2中有一个为true时result就为true。
这里注意:“||”运算符与“|”运算符不同。||具有短路特性,即当expression1为true时,那么expression2将不会在被执行。
对此我们就可以借用这个特性,如下:
function a(){ this.b = this.b || "test"; } a();
我们可以看到,当函数第一次被调用时,因为this.b为null,所以就会执行第二个表达式,给b赋值为“test”。
这样我们利用这个特性就实现了对b进行初始化,对于这种用法有些时候会很好的解决一些全局变量泛滥的问题。
"&&"的使用:
在javascript以及许多语言中,&&(逻辑与)运算符,作用是:对两个表达式取与运算
result
=
expression1
||
expression2
当expression1与expression2都为为true时result才为true。
这里注意:“&&”运算符与“&”运算符不同。&&也是具有短路特性,即当expression1为false时,那么expression2将不会在被执行。
这样我们也可以利用这个特性来完成我们的一些工作,如下:
function a(cb){ cb && cb(); } cb = function(){ alert("cb"); }; a(); a(cb);
我们可以看到,a函数需要一个参数cb,cb为一个函数。当执行a();时。cb没有被传过去,那么cb就为null(false)了。从而cb();也就不会执行了。
当执行到a(cb)时,cb存在了所以为true,那么第二个表达式cb();就会执行。从而避免了错误的发生。如果在a函数中不使用&&运算,直接调用cb()
的话就会发生cb不是函数的错误。
希望对大家有帮助。