为什么console.log在分配之前会记录一个值?

时间:2013-09-19 15:38:30

标签: javascript

一个简短的例子:

self.curTabs = null;

$j.getJSON(url)
    .done(function (response) {
        self.curTabs = response.tabs;

        _.each(self.curTabs, function (tab) {
            tab.dataLoaded = true;
        });

        console.log(self.curTabs);
    });

逻辑输出:[ 0: Object { dataLoaded: true, etc... }, 1: etc... ]

但是这个例子:

self.curTabs = null;

$j.getJSON(url)
    .done(function (response) {
        self.curTabs = response.tabs;

        _.each(self.curTabs, function (tab) {
            tab.dataLoaded = true;
        });

        console.log(self.curTabs);

        _.each(self.curTabs, function (tab) {
            tab.dataLoaded = false;
        });
    });

不合逻辑的输出:[ 0: Object { dataLoaded: false, etc... }, 1: etc... ]

为什么变量在赋值之前得到值false

1 个答案:

答案 0 :(得分:10)

因为console.log在每个实现中都不是同步的。这样它排队直到主线完成。在此期间,您的新值已设置。