6

我正在尝试使用console.log调试一些非常简单的Javascript,但它输出的变量值在console.log调用之后才会更改,此时变量是“类”成员(Chrome 22、Firefox 16)。

我期望发生的一个例子是这样的:

var a = 1;
console.log(a);
a += 20;

//console output says a is 1

但如果变量是“类”成员:

var a = new myClass(1);
console.log(a);
a.x += 20;

//console output says a.x is 21

如果控制台没有记录调用日志时存在的值,它最终决定何时记录该值,我该如何解决这个问题!?

fwiw 这里是整个代码:

function myClass() {
    myClass.myClass.apply(this, arguments);
    if (this.constructor === myClass) this.myClass.apply(this, arguments);
};
myClass.myClass = function () {};
myClass.prototype.myClass = function (x_) {
    if (x_ === undefined) x_ = 0;
    this.x = x_;
}

var a = new myClass(1);
console.log(a);
a.x += 20;
4

1 回答 1

8

立即,但是当您在控制台中手动扩展对象时会获取对象的状态- 而不是在记录时。

当您在控制台中展开它时,添加 20 的代码已经在很久以前(相对而言)执行了,它说x: 21

于 2012-11-04T11:54:03.827 回答