如何打印从Node.js中的mongoDB数据库中检索的数据?

时间:2017-01-08 15:23:45

标签: javascript node.js mongodb mongoose mongodb-query

我正在开展网上商店项目。我使用mongoose使用Node.js,express.js和MongoDB。我从MongoDB数据库获取了产品信息并将它们发送到客户端。在我的情况下,我可以在客户端获取所有这些数据,但在发送之前,当我将它们打印到服务器端的控制台时,它表示未定义。

这是产品架构:

var schema = new Schema({
    imagePath: {
        type: String,
        required: true
    },
    productName: {
        type: String,
        required: true
    },
    productPrice: {
        type: Number,
        required: true
    },
    productCategory: {
        type: String,
        required: true
    },
    productShortInformation: {
        type: String,
        required: true
    },
    productFullInformation: {
        type: String,
        required: true
    },
    productViews: {
        type: Number,
        required: false
    },
    productStock: {
        type: Number,
        required: true
    }
});

这是我的Node.js代码

router.get('/category/summary', function(req, res, next) {
    //getting my all products information
    var products = Product.find(function (err, docs) {
        if(err) {
            console.log('Error Happened'  + err);
            return res.redirect('/');
        } else {
            //HERE IS THE PROBLEM
            //ALL PRODUCT NAME IS SHOWN UNDEFINED
            //BUT WHEN I SEND THEM TO THE CLIENT, I GET PRODUCT NAME
            for(var product in docs) {
                console.log('Name: ' + product.productName);
            }

            res.render('shop/categorySummary', {
                products: docs  //sending these information to the client side
            });
        }
    });
});

当我尝试打印这些产品name时,我得到了未定义。但在客户端,我可以打印产品信息。

我需要在将这些数据发送到客户端之前对其进行操作。那么如何在发送之前将这些产品信息打印到服务器端(在控制台中)?

1 个答案:

答案 0 :(得分:3)

for(var product in docs) {
     console.log('Name: ' + docs[product].productName);
}

那应该有用