在javascript中,“ for..in”语句如何产生副作用?

时间:2019-03-07 09:42:39

标签: javascript side-effects javascriptcore

我想知道for .. in有什么副作用吗?

let arr = [1.1, 2.2];
let obj = {x: 1, y: 1, z: 1};
for(let prop in obj) {
    ...
}

考虑到上面的代码片段,是否可以更改arr语句中for .. in中的某些元素而不是在循环体内?

我目前正在分析JavaScriptCore JIT编译器,DFG假设GetPropertyEnumerator有副作用,据我了解,它可以更改for .. in语句中的其他对象。
但是,我不知道怎么可能。
所以我想做到这一点,如果可能的话,我该怎么做。

1 个答案:

答案 0 :(得分:1)

我自己找到了这个问题的答案:)
https://github.com/WebKit/webkit/commit/243a17dd57da84426316502c5346766429f2456d
上面的提交日志对我很有帮助!

Proxy对象具有名为getPrototypeOf的成员。
通过使用此getPrototypeOf,我可以在for .. in语句的属性查找阶段修改一些对象。

let a = {x: 1, y: 2, z: 3};
a.__proto__ = {xx: 1, yy: 2, zz: 3};

for(let i in a) {
    print(i);
}

上面是一个简单的例子。
for .. in语句查找对象a的属性,然后遵循a的__proto__链。
在这种情况下,代理服务器的getPrototypeOf__proto__查找的陷阱。
示例如下。

let a = {
  x: 1,
  y: 2,
  z: 3
};
let p = new Proxy(a, {
  getPrototypeOf: function() {
    console.log("getPrototypeOf - side effects can be caused here");
    return {
      a: 1,
      b: 2
    };
  }
});

for (let i in p) {
  console.log(i);
}