将GET参数传递给Express + Mongoose Restful API

时间:2014-03-17 23:27:26

标签: jquery node.js mongodb express mongoose

我刚刚进入Node,Express和Mongoose。到目前为止还爱它,但无法弄清楚如何将AJo调用中的MongoDB过滤传递给API。

我有一个简单的jQuery AJAX请求:

$.getJSON('/api/products', {
    filter: { status: 'active' } // <-- Want this to get processed by the API
}, function(products){
    console.log(products);
});

以下是Express + Mongoose API的重要部分:

// Define Mongoose Schema
var Schema = mongoose.Schema;

// Product Schema
var ProductSchema = new Schema({
    name: { type: 'string', required: false },
    price: { type: 'number', required: false },
    status: { type: 'string', required: false },
    description: { type: 'string', required: false },
});

// Product Model
var ProductModel = mongoose.model('Product', ProductSchema);

// Product Endpoint
app.get('/api/products', function(req, res){
    return ProductModel.find(function(error, products){
        return res.send(products);
    });
});

1 个答案:

答案 0 :(得分:6)

您应该按照原样发送带编码的参数。现在您只需要获取它们并将其传递给您的查询:

// Product Endpoint
app.get('/api/products', function(req, res){

    var filter =  {};
    for ( var k in req.query.filter ) {
        filter[k] = req.query.filter[k];   // probably want to check in the loop
    }
    return ProductModel.find(filter, function(error, products){
        return res.send(products);
    });
});

那个循环就在那里,因为你可能想要查看发送的内容。但是我会把它留给你。

如果符合您的口味,也req.params