js逻辑与,或,非
【转,未整理】
1、逻辑非(!)
如果一个操作数是一个对象,返回true;
如果一个操作数是一个空字符串,返回false;
如果一个操作数是一个非空字符串,返回false;
如果一个操作数是一个数值0,返回false;
如果一个操作数是任意的非零字符,返回true;
如果一个操作数是null,返回false;
如果一个操作数是NaN,返回false;
如果一个操作数是undefined,返回true;
2、逻辑与(&&)
(1)对于布尔值,逻辑与是非常简单的,只要有一个false,就返回false;
(2)对于不是布尔值的情况则:
如果第一个操作数是对象,则返回第二个数
如果第二个操作数是对象,则只有在第一个操作数的求值结果为true的情况下才会返回该对象;
如果第两个操作数都是对象,则返回第二个数操作数
如果有一个操作数是null,则返回null
如果有一个操作数是NaN,则返回第NaN
如果第一个操作数是undefined,则返回unfined
上面确实难记,举例子来论证下会更方便记住
var obj={}; var a=(obj && null); alert(a) //null
var obj={}; var a=(null && obj); alert(a) //null
var obj={}; var a=(obj && undefined); alert(a) //undefined
var obj={}; var a=(undefined && obj); alert(a) //undefined
var obj={}; var a=(obj && NaN); alert(a) //NaN
var obj={}; var a=(NaN && obj ); alert(a) //NaN
var obj={};var obj2={} ; var a=(obj && obj2); alert(a==obj2) //true
对于逻辑与的短路问题:
举例1
<script type="text/javascript">
var found=true;var result=(found && someUdefinedVariable);alert(result);//显示someUdefinedVariable
//例子中的found为true,所以会对someUdefinedVariable继续求值,但是该变量未定义,所以会提示错误
</script>
举例2
<script type="text/javascript">
var found=false;var result=(found && someUdefinedVariable);alert(result);//显示false
//例子中的found为false,所以第一个操作数就已经能够决定结果,就不会在对第二个操作数求值
</script>
ps:对于逻辑与,如果第一个操作数十false,无论第二个操作数是什么,结果都不可能在世true
3、逻辑或(||)
(1)对于布尔值,逻辑或是非常简单的,只要有一个true,就返回true;
(2)对于不是布尔值的情况则:
如果第一个操作数是对象,则返第一个操作数
如果第一个操作数的求值结果为false,则返回第二个操作数
如果两个操作数都是对象,则返回第一个操作数
如果两个操作数是null,则返回null
如果两个操作数是NaN,则返回NaN
如果两个操作数是undefined,则返回undefined
例子1
<script type="text/javascript">
var found=true;
var result=(found || someUdefinedVariable);
alert(result);//弹出true
//对于逻辑与,当一个为true的时候,就不会在对第二个操作数进行求职了
</script>