如何在Meteor应用程序的Mongo查询中将变量用作字段名称。
这是一个例子......
在大写子集的父ID的集合名称之后,它会在我的请求控制器集合上运行查找。孩子是用户字段。
window[Meteor.request.controller.capitalise()]["find"]({ _id: Session.get('parent_id'), users: params.child }).count()
正如您所看到的,我的控制器是集合项的变量名,它允许我有一行代码来查找控制器/集合的子代,但我需要能够将子字段名设置为变量。在上面的示例中,用户但我希望它是变量名。
我试过这个,但它不起作用。
window[Meteor.request.controller.capitalise()]["find"]({ _id: Session.get('parent_id'), [Session.get('child_collection_name').decapitalise()]: params.child }).count()
,其中
Session.get('child_collection_name').decapitalise()
返回用户
有什么想法吗?如果我能弄清楚如何在meteor中使用mongo查询中的变量名,那么它将大大减少我的代码占用量。
答案 0 :(得分:14)
查询只是一个JavaScript对象,因此您可以逐步构建它:
var query = { _id: Session.get('parent_id') };
var myCustomField = Session.get('child_collection_name').decapitalise();
var myCustomValue = params.child;
query[myCustomField] = myCustomValue;
var count = SomeCollection.find(query).count();
这样做可以吗?