zoukankan      html  css  js  c++  java
  • Javascript 中的 && 和 || 使用小结

    &&操作符

       在 javascript 中,对于 && 不仅仅可以用于 boolean 类型,也不仅仅返回 Boolean 类型的结果。 

    • 如果第一个操作数是 Boolean 类型,而且值为 false ,那么直接返回 false。
    • 如果第一个操作数是 Boolean 类型,而且值为 true,另外一个操作数是 object 类型,那么将返回这个对象。
    • 如果两个操作数都是 object 类型,那么,返回第二个对象。
    • 如果任何一个操作数是 null,那么,返回 null。
    • 如果任何一个操作数是 NaN,那么返回 NaN。
    • 如果任何一个操作数是 undefinded,那么返回 undefined。
    alert(false && alice); // false 
    alert(true && alice); // alice 
    
    alert(alice && smith); // smith 
    alert(smith && alice); // alice 
    
    alert(null && alice); // null 
    alert(NaN && alice); // NaN 
    alert(undefined && alice); // undefined 
    alert(alice && undefined); // undefined 

    ||操作符

    对于 || 来说,同样也不仅仅用于 Boolean 类型,也不仅仅返回 Boolean 类型的结果。 事实上,null、undefined、NaN 都将被看作 false。而对象被当作 true。 

    • 如果第一个操作数是 Boolean 类型,而且值为 true, 那么,直接返回 true。
    • 如果第一个操作数是 Boolean 类型,而且值为 false ,第二个操作数为 Object,那么返回 object 对象。
    • 如果两个操作数都是 Object 类型,那么返回第一个对象。
    • 如果两个操作数都是 null,那么,返回 null。
    • 如果两个操作数都是 NaN,那么返回 NaN。
    • 如果两个操作数都是 undefined,那么,返回 undefined。 
    alert(false || alice);         // alice
    alert(true || alice);          // true
     
    alert('alice' || 'smith');         // 'alice' 
    alert('smith' || 'alice');         // 'smith'
     
    alert(null || 'alice');       // 'alice' 
    alert('alice' || null);       // 'alice' 
    alert(null || null);        // null
     
    alert(NaN || 'alice');        // 'alice'
    alert('alice' || NaN);        // 'alice'
    alert(NaN || NaN);          // NaN
     
    alert(undefined || 'alice');     // 'alice'
    alert('alice' || undefined);     // alice
    alert(undefined || undefined); // undefined

     小技巧

    a && b : 将a, b转换为Boolean类型, 再执行逻辑与, true返回b, false返回a
    a || b : 将a, b转换为Boolean类型, 再执行逻辑或, true返回a, false返回b 

    转换规则: 对象为true 、非零数字为true、 非空字符串为true、 其他为false 

  • 相关阅读:
    20155207 2016-2017-2《Java程序设计》课程总结
    Mycp补交作业
    20155207 实验五 网络编程与安全
    20155206 随堂作业
    20155206 《Java程序设计》实验三实验报告
    20155206 2016-2017-2 《Java程序设计》第十周学习总结
    20155206 《JAVA程序设计》实验二(JAVA面向对象程序设计)实验报告
    20155206 2016-2017-2 《Java程序设计》第9周学习总结
    20155206 2016-2017-2 《Java程序设计》第8周学习总结
    20155206 实验一《Java开发环境的熟悉》实验报告
  • 原文地址:https://www.cnblogs.com/guorange/p/7262125.html
Copyright © 2011-2022 走看看