首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么‘x === x++`’在Javascript中是true而`x++ === x‘false?

为什么‘x === x++`’在Javascript中是true而`x++ === x‘false?
EN

Stack Overflow用户
提问于 2019-12-25 10:57:29
回答 11查看 626关注 0票数 3

您能解释一下这两个逻辑操作之间的区别吗:

代码语言:javascript
复制
let x = 1;

console.log('x = ' + x);
console.log('x ===  x++ : ' + (x ===  x++));

x = 1;

console.log('x = ' + x);
console.log('x++ ===  x : ' + (x++ ===  x));

EN

回答 11

Stack Overflow用户

回答已采纳

发布于 2019-12-25 11:07:57

后缀增量(y = x++)确实增加了值,但计算结果是它以前的值。它几乎等于:

代码语言:javascript
复制
  x² = x; // evaluate previous value of x
  x += 1; // increase x
  y = x²; // use previous value

因此,x === x++等于:

代码语言:javascript
复制
  // evaluate left side of ===
  x¹ = x;
  // evaluate right side
  x² = x;
  // ++
  x += 1;
  // comparison
  x¹ === x² // true

我们的x++ === x是:

代码语言:javascript
复制
  // evaluate left side
  x¹ = x;
  // ++
  x += 1;
  // evaluate right side
  x² = x; // x was already incremented!
  // comparison
  x¹ === x²
票数 4
EN

Stack Overflow用户

发布于 2019-12-25 11:01:07

X === x++:首先比较x与x,然后x++ x++ === x:第一个x++,然后将x++的结果与x进行比较

票数 4
EN

Stack Overflow用户

发布于 2019-12-25 11:14:25

在javascript中计算===运算符时,它首先计算左操作数,然后计算右操作数,然后在最后一个操作数中进行比较。见ecma262

并且,在计算x++时,x的值会发生变化,而x++的结果是x的原始(不变)值。

因此,在x === x++中,xx++都计算为x的原始值,在此之后x的值发生了变化。结果是true

x++ === x中,计算左x++时更改x值,左操作数计算为原始值。但在此之后,右operand将执行操作数,因此它将计算为更改后的x值。结果是false

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59477674

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档