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>               

 

posted @ 2014-11-08 15:16  幻想家~  阅读(3717)  评论(0编辑  收藏  举报