博客
关于我
JavaScript学习总结(三)——逻辑And运算符详解
阅读量:356 次
发布时间:2019-03-04

本文共 1095 字,大约阅读时间需要 3 分钟。

JavaScript逻辑AND运算符的行为规则

在JavaScript中,逻辑AND运算符(&&)用于逻辑与操作。它的运算行为与其他语言如Java类似,即只要第一个运算数为false,结果将直接为false,无需计算第二个运算数。

运算规则

  • 非布尔类型支持

    JavaScript中的逻辑AND运算不仅支持布尔值,还可以处理其他数据类型。

    • 如果一个运算数是对象,另一个是布尔值,结果返回该对象。
    • 如果两个运算数都是对象,结果返回第二个对象。
    • 如果某个运算数是null或NaN,结果也会是null或NaN。
    • 如果某个运算数是undefined,会抛出错误。
  • 简便性

    JavaScript的逻辑AND运算具有简便性。

    • 如果第一个运算数为false,结果直接为false,无需计算第二个运算数。
    • 如果第一个运算数为true,才会继续计算第二个运算数的值。
  • 示例验证

    以下是几个实际示例,帮助理解逻辑AND运算的行为:

  • 布尔值运算

    var bTrue = true;var bFalse = false;var bResult = bTrue && bFalse; // 结果:false
    • 当两个布尔值分别为true和false时,结果为false。
  • 对象与布尔值运算

    var obj = {};var result = true && obj; // 返回objresult = false && obj; // 返回false
    • 当一个运算数是对象时,结果返回该对象,但如果第一个运算数为false,则返回false。
  • 对象与对象运算

    var obj1 = {};var obj2 = {};var result = obj1 && obj2; // 返回obj2
    • 当两个运算数都是对象时,结果返回第二个对象。
  • 注意事项

    • 未定义变量

      在以下代码中,bUnknown未定义,会导致错误:

      var bTrue = true;var bResult = bTrue && bUnknown; // 错误

      但如果第一个运算数为false,则不会执行第二个运算:

      var bFalse = false;var bResult = bFalse && bUnknown; // 返回false,无错误
    • 错误处理

      如果某个运算数是undefined,JavaScript会抛出TypeError错误。例如:

      var a = undefined;var b = true;a && b; // 抛出TypeError

    通过以上示例,可以清晰地看到JavaScript逻辑AND运算符的复杂性和灵活性。

    转载地址:http://nikr.baihongyu.com/

    你可能感兴趣的文章
    Oracle 并行原理与示例总结
    查看>>
    oracle 并集 时间_Oracle集合运算符 交集 并集 差集
    查看>>
    Oracle 序列sequence 开始于某个值(10)执行完nextval 发现查出的值比10还小的解释
    查看>>
    oracle 执行一条查询语句,把数据加载到页面或者前台发生的事情
    查看>>
    oracle 批量生成建同义词语句和付权语句
    查看>>
    oracle 抓包工具,shell 安装oracle和pfring(抓包) 及自动环境配置
    查看>>
    Oracle 拆分以逗号分隔的字符串为多行数据
    查看>>
    Oracle 排序中使用nulls first 或者nulls last 语法
    查看>>
    oracle 插入date日期类型的数据、插入从表中查出的数据,使用表中的默认数据
    查看>>
    Oracle 操作笔记
    查看>>
    oracle 数据库 安装 和优化
    查看>>
    oracle 数据库dg搭建规范1
    查看>>
    Oracle 数据库常用SQL语句(1)
    查看>>
    Oracle 数据库特殊查询总结
    查看>>
    Oracle 数据类型
    查看>>
    oracle 数据迁移 怎么保证 和原表的数据顺序一致_一个比传统数据库快 1001000 倍的数据库,来看一看?...
    查看>>
    oracle 时间函数
    查看>>
    oracle 时间转化函数及常见函数 .
    查看>>
    Oracle 权限(grant、revoke)
    查看>>
    oracle 查询clob
    查看>>