首页/javascript外包/js逻辑与,或,非

js逻辑与,或,非

发布-xiaoming | 浏览量-

 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>     

原文地址:http://www.35ui.cn/post/2016031122..html

标签jsjavascript

上一条: 403 Forbidden是什么意思,怎么解决这个问题?
下一条: jquery滚动条加载数据

或许你还对下面的文章感兴趣