• 理解运算符&&的三个不同层次


    “&&”运算符可以从三个不同的层次进行理解。

    第一层理解

    当操作数都是布尔值时,“&&”对两个值执行布尔与(AND)操作。

    x==0 && y==0        // 只有当x和y都是0时,才返回true

    关系运算符的优先级比”&&”要高。

    第二层理解

    ”&&“可以对真值和假值进行布尔与(AND)操作。(假值有false、null、undefined、0、NaN和”“)。在JS中任何希望使用布尔值的地方,表达式和语句都会将其当做真值或假值来对待,因此实际上”&&”并不总是返回true和false。

    null && true        // =>null: 左操作数为假值,并将其返回,整个表达式为假
    true && (5 - 3)     // =>2: 左操作数为真,计算右操作数,并将其结果返回

    第三层理解

    当运算符要返回一个真值或假值时,根据左操作数的值会遇到两种运算情况:运算符首先计算左操作数的值,如果计算结果是假值,那么整个表达式的结果一定也是假值,此时”&&“简单的返回左操作数的值,而并不会对右操作数进行计算。如果左操作数是真值,”&&“将计算右操作数的值并将其返回作为整个表达式的计算结果。

    var o = {x:1};
    var p = null;
    o && o.x;        // =>1 o是真值,返回o.x的值
    p && p.y;        // =>null: p是假值,将其返回,而不去计算p.y

    ”&&“的行为有时称作”短路“,我们将会看到很多代码利用了这一特性进行有条件地执行代码。例如下面两行代码是完全等价的:

    if(a == b) stop();
    (a == b) && stop();// 与上面语句等价

    知识延伸

    运算符“||”和”&&”一样也具有一些复杂的行为。

    用来从一组备选表达式中选出第一个真值表达式:

    // 先检查a是否是真值,如果是,返回a,否则和a处理方式相同地处理b
    // 如果b是真值返回b,否则返回5
    var max = a || b || 5;

    这种用法在函数中可以用来给参数提供默认值:

    function copy(o, p) {
        p = p || {};    // 如果没有向参数p传递对象,就使用新创建的对象
        // ...
    }

    运算符优先级

    同一优先级的运算符,运算次序由结合方向所决定。

    简单记就是:! > 算术运算符 > 关系运算符 > && > || > 赋值运算符

  • 相关阅读:
    ElementUI表格表头自定义添加checkbox,点击不生效问题
    同步个人vs code 习惯性配置gists 到码云(Gitee)
    el-select 设置宽度自适应上层div
    vue-element-template模板vue-cli3本地使用proxy解决跨域问题
    vue-cli3用axios+proxy简单解决在dev开发环境下的跨域问题
    windows下EasyMock的安装与部署遇到的各种问题(爬坑)
    git同步代码至github和gitee(码云)
    Git使用总结(包含Git Bash和Git GUI的使用)
    Leetcode No.53 Maximum Subarray(c++实现)
    Leetcode No.35 Search Insert Position(c++实现)
  • 原文地址:https://www.cnblogs.com/mackxu/p/luojiyu.html
Copyright © 2020-2023  润新知