加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 运营中心 > 搜索优化 > 正文

运算符的三个不同层次的基础知识

发布时间:2022-06-07 21:46:45 所属栏目:搜索优化 来源:互联网
导读:运算符可以从三个不同的层次进行理解。 第一层理解 当操作数都是布尔值时,对两个值执行布尔与(AND)操作。 复制代码 代码如下: x==0 y==0 // 只有当x和y都是0时,才返回true 关系运算符的优先级比要高。 第二层理解 可以对真值和假值进行布尔与(AND)操作。
  运算符可以从三个不同的层次进行理解。
 
  第一层理解
 
  当操作数都是布尔值时,“&&”对两个值执行布尔与(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传递对象,就使用新创建的对象
 
  // ...
 
  }
 
  运算符优先级
 
  同一优先级的运算符,运算次序由结合方向所决定。
 
  简单记就是:! > 算术运算符 > 关系运算符 > && > || > 赋值运算符。
 

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读