为什么在foreach函数回调中对全局变量所做的更改不能反映回调



我正在尝试从mongoDB图集中检索一些文档,下面是代码:

get('/:page/bucket_names', (req, res) => {
    var page = req.params.page;
    var pageBuckets = [];
    MongoClient.connect(uri, (err, client) => {
        if (err) res.send('error:' + err);
        const db = client.db("cms");
        db.collection(page).find({ $or: [{ type: 'single' }, { type: 'carousel' }, { type: 'freelist' }] }, (err, result) => {
            if (err) res.send('error');
            else {
                result.forEach(el => {
                    pageBuckets.push(el);
                    console.log(pageBuckets) //1
                })
                console.log(pageBuckets)  //2
            }
        })
        client.close();
    })
})

第一个控制台.log输出更新的 pageBuckets 数组,但第二个控制台.log输出一个空数组。我无法理解问题是什么。

原来第二个

控制台.log在foreach循环之前被执行,所以用下面的代码修复它:

result.forEach(el =>{
        pageBuckets.push(el);
          console.log(pageBuckets) //1
      }).then(() =>{
        console.log(pageBuckets); //2
      })

最新更新