zoukankan      html  css  js  c++  java
  • javascript逻辑运算符“||”和“&&”

    逻辑||

    请测试下面代码:

    alert(0||1);

    显然,我们知道,前面0意味着false,而后面1意味着true,那么上面的结果应该是true,而事实返回的结果是1。

    再看下面代码:

    alert(2||1);

    我们知道,前面2是true,后面1也是true,那返回结果又是什么呢?测试结果是2

    alert('a'||'b');

    前面'a'是true,后面'b'是false,返回结果是'a'

    alert(''||0);

     前面''是false,后面0同样是false,返回结果是0

    alert(0||'');

    前面0是false,后面''是false,返回结果是''

    这就意味

    1、只要“||”前面为false,不管“||”后面是true还是false,都返回“||”后面的值。

    2、只要“||”前面为true,不管“||”后面是true还是false,都返回“||”前面的值。

    逻辑&&

    alert(''&&1);

    结果是返回'',“&&”前面''是false,后面是1是true。

    alert('a'&&1);

    结是返回1,“&&”前面''a是true,后面是1也是true。

    alert(0&&'a');

    结是返回0,“&&”前面''0是false,后面是'a'是true。

    这意味着

    1、只要“&&”前面是false,无论“&&”后面是true还是false,结果都将返“&&”前面的值;

    2、只要“&&”前面是true,无论“&&”后面是true还是false,结果都将返“&&”后面的值;

    由上两个测试可知,逻辑运算符,“||”和“&&”都是遵行短路原则,只要确定符号前面的真假,既可确定返回值。

    重点说的是&&的优先级高于||

    alert(1||'a'&&2);

    返回结果是1。

  • 相关阅读:
    C++中左移<<的使用
    学会构造素数序列
    有关lower_bound()函数的使用
    Codeforces Round #166 (Div. 2)
    暴力swap导致TLE问题解决办法
    memset的正确使用
    Codeforces Round #297 (Div. 2)
    Codeforces Round #170 (Div. 2)B
    Codeforces Round #176 (Div. 2)
    C/C++ sort函数的用法
  • 原文地址:https://www.cnblogs.com/cnundefined/p/7002383.html
Copyright © 2011-2022 走看看