1

所以,我正在 Node 中编写一个页面抓取工具,并且在一组回调中从 Date.getTime 得到奇怪的行为。

function projectScrape(urlList){
        urlList.forEach(function(frag){
                request(frag.url, (function(frag){
                        return function(err, resp, body){
                                if(err) console.log('error: ' + err);
                                project$ = cheerio.load(body);
                                var tempRecord = {
                                        name: frag.name,
                                        funding: project$('span.monthly_funding_goal_percentage').text($
                                        subs: project$('span.number_of_subscribers').text(),
                                        timestamp: myDate.getTime()
                                        };
                                console.log(tempRecord);
                        }
                })(frag));
        });
};

刮擦工作正常,我从网站上获得了一系列控制台转储。但是,所有这些上的时间戳都是相同的。回调显然没有同时完成(有时在回调响应之间长达几秒钟) - 那么为什么它们的时间戳是相同的毫秒?

我在这里错过了有关功能范围的信息吗?正如我所看到的,即使所有回调都引用 Date.getTime() 的同一实例,控制台转储也应该将时间戳冻结到各个回调返回的时间。

我能想到的唯一解释是 Date.getTime() 值是在创建回调时存储的,而不是在它们实际触发时更新。

任何人都可以在这里阐明一下吗?

4

1 回答 1

2

如果Date.now()您想要当前时间戳,而不是.getTime()固定日期,请使用。除非您myDate以任何方式进行修改,否则它将始终引用相同的时间和日期,因此.getTime()将始终返回相同的值:

var tempRecord = {
  name: frag.name,
  funding: project$('span.monthly_funding_goal_percentage').text(/* ... */),
  subs: project$('span.number_of_subscribers').text(),
  timestamp: Date.now() // <---------
};

不要使用(new Date()).getTime()orvar myTempDate = new Date(); return myTempDate.getTime()因为它们会创建新对象。您不需要它们,它们甚至可能会减慢您的应用程序(取决于 GC 实现)。

于 2013-09-17T09:01:25.067 回答