Nei*_*eil 31 javascript underscore.js
我试图使用Underscore.js搜索一组对象,但我似乎无法定位我想要的对象.
console.log(_.findWhere(response.data, { TaskCategory: { TaskCategoryId: $routeParams.TaskCategory } }));
Run Code Online (Sandbox Code Playgroud)
但是,这是返回undefined
$routeParams.TaskCategory等于301
这是我正在搜索的数组中的对象的示例.这个数据用.表示data.response
[{
"TaskCategory": {
"TaskCategoryId": 201,
"TaskName": "TaskName"
},
"TaskCount": 1,
"Tasks": [{
"EventTypeId": 201,
"EventName": "Event Driver",
"EventDate": "0001-01-01T00:00:00",
"EventId": "00000000-0000-0000-0000-000000000000",
}]
},
{
"TaskCategory": {
"TaskCategoryId": 301,
"TaskName": "TaskName"
},
"TaskCount": 1,
"Tasks": [{
"EventTypeId": 201,
"EventName": "Event Driver",
"EventDate": "0001-01-01T00:00:00",
"EventId": "00000000-0000-0000-0000-000000000000",
}]
}]
Run Code Online (Sandbox Code Playgroud)
所以我希望使用该数组中的第二个对象TaskCategory.TaskCategoryId,是否可以使用Underscore获取它?
McG*_*gle 56
使用_.find而不是findWhere:
console.log(_.find(response.data, function(item) {
return item.TaskCategory.TaskCategoryId == $routeParams.TaskCategory;
}));
Run Code Online (Sandbox Code Playgroud)
它们是相似的,但是findWhere设计用于您希望匹配键值对的特殊情况(在您的场景中对于涉及嵌套对象没有用). Find更通用,因为它允许您提供函数作为谓词.
_.findWhere/ 的来源_.where如下
_.where = function(obj, attrs, first) {
if (_.isEmpty(attrs)) return first ? void 0 : [];
return _[first ? 'find' : 'filter'](obj, function(value) {
for (var key in attrs) {
if (attrs[key] !== value[key]) return false;
}
return true;
});
};
_.findWhere = function(obj, attrs) {
return _.where(obj, attrs, true);
};
Run Code Online (Sandbox Code Playgroud)
如您所见,它执行严格的平等而非深度平等.如果你想深入搜索,那就足够了(未经测试,未经优化):
_.whereDeep = function(obj, attrs, first) {
if (_.isEmpty(attrs)) return first ? void 0 : [];
return _[first ? 'find' : 'filter'](obj, function(value) {
for (var key in attrs) {
if (attrs[key] !== value[key] || !(_.isObject(attrs[key]) && _.whereDeep([value[key]], attrs[key], true))) return false;
}
return true;
});
};
_.findWhereDeep = function(obj, attrs) {
return _.whereDeep(obj, attrs, true);
};
Run Code Online (Sandbox Code Playgroud)
而且你可以使用你的代码,几乎不变
_.findWhereDeep(response.data, { TaskCategory: { TaskCategoryId: $routeParams.TaskCategory } });
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
61580 次 |
| 最近记录: |