为什么解构与Javascript(ES6)中的经典赋值不同?

Mof*_*off 5 javascript destructuring ecmascript-6

正如你在这里看到的那样,我们将"fibonacci"设置为"可迭代"对象,然后使用for ...循环它:

let fibonacci = {
              [Symbol.iterator]() { 
                let pre = 0, cur = 1;
                return {
                  next() {
                    [pre, cur] = [cur, pre + cur];
                    return { done: false, value: cur }
                  }
                }
              }
            }

            for (var n of fibonacci) {
              // truncate the sequence at 1000
              if (n > 1000)
                break;
              console.log(n);
            }
Run Code Online (Sandbox Code Playgroud)

正如预期的循环,控制台日志写1,2,3,5,8,..

如果我写pre = cur; cur = pre + cur;而不是[pre, cur] = [cur, pre + cur];

console.log会写2,4,8,16,..

为什么?不是解构只是一种在一行中设置多个值的方法吗?我们如何解释分配的差异?

Nin*_*olz 6

pre = cur; cur = pre + cur; 
Run Code Online (Sandbox Code Playgroud)

通过赋值pre,您丢失了旧值,pre下一个赋值错误.

pre  cur  comment           values
---  ---  ----------------  -------
  0    1  start values         *
  1    1  pre = cur
  1    2  cur = pre + cur      *
  2    2  pre = cur
  2    4  cur = pre + cur      *
Run Code Online (Sandbox Code Playgroud)
[pre, cur] = [cur, pre + cur];
Run Code Online (Sandbox Code Playgroud)

解构赋值保持值,直到整个阵列的分配.