zoukankan      html  css  js  c++  java
  • && ||的一些技巧应用

    普通情况下的 && 和 || 比较简单,这里不进行讨论。

    准备两个对象用于下面的讨论。

    复制代码 代码如下:

    var alice = {
    name: "alice",
    toString: function () {
    return this.name;
    }
    }

    var smith = {
    name: "smith",
    toString: function () {
    return this.name;
    }
    }


    在 javascript 中,对于 && 不仅仅可以用于 boolean 类型,也不仅仅返回 Boolean 类型的结果。
    l 如果第一个操作数是 Boolean 类型,而且值为 false ,那么直接返回 false。
    l 如果第一个操作数是 Boolean 类型,而且值为 true,另外一个操作数是 object 类型,那么将返回这个对象。
    l 如果两个操作数都是 object 类型,那么,返回第二个对象。
    l 如果任何一个操作数是 null,那么,返回 null。
    l 如果任何一个操作数是 NaN,那么返回 NaN。
    l 如果任何一个操作数是 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。

    l 如果第一个操作数是 boolean 类型,而且值为 true, 那么,直接返回 true。
    l 如果第一个操作数是 Boolean 类型,而且值为 false ,第二个操作数为 object,那么返回 object 对象。
    l 如果两个操作数都是 object 类型,那么返回第一个对象。
    l 如果两个操作数都是 null,那么,返回 null。
    l 如果两个操作数都是 NaN,那么返回 NaN。
    l 如果两个操作数都是 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

  • 相关阅读:
    python--函数的返回值、函数的参数
    python--字典,解包
    Vue--ElementUI实现头部组件和左侧组件效果
    Vue--整体页面布局
    jmeter--non GUI
    python--切片,字符串操作
    celery--调用异步任务的三种方法和task参数
    celery--实现异步任务
    celery--介绍
    开发问题记录
  • 原文地址:https://www.cnblogs.com/aishangliming/p/6376613.html
Copyright © 2011-2022 走看看