gpt4 book ai didi

angularjs - $.grep 在匹配后返回属性

转载 作者:行者123 更新时间:2023-12-02 23:37:21 24 4
gpt4 key购买 nike

我找不到任何这样做的实例,所以我问你们聪明的人是否有一个很好的简单方法来完成我想要的事情。

尝试将两个数组映射在一起。一个数组包含 ID 列表 (Foos),另一个数组包含这些 ID 的所有属性(条)。想要将所有内容保留在我的 Angular Controller 中。

这是一个片段。我正在尝试匹配 ID 并映射到 Name 属性。

$scope.Foos = $.map($scope.Foos, function (foo) {
return {
ID: foo.ID,
Name: $.grep($scope.bars, function(b){
return b.ID === foo.ID;
}).Name,
Property: $.grep($scope.bars, function(b){
return b.ID === foo.ID;
}).Property
};
});

我的理解是 $.grep 将根据条件返回对象,然后我可以调用该返回对象的属性吗?

更新:

Foos 是 ID(引导)Bars 是 ID(guid)、名称和属性

最佳答案

$.grep返回一个数组,而不是一个对象,因此要执行您想要的操作,您需要执行以下操作:

Name: $.grep($scope.bars, function(b){
return b.ID === foo.ID;
})[0].Name

但是这里的问题是如果没有匹配,$.grep将返回一个空数组,并且您最终会在尝试从该空数组中获取第一个元素时抛出错误。

您确实应该首先查找属性,而不是在尝试构建更复杂的对象时

类似于:

$scope.Foos = $.map($scope.Foos, function (foo) {
// first filter the array
var bars = $.grep($scope.bars, function (b) {
return b.ID === foo.ID;
});
// now test we have result, if not make it ... empty string???
var name = bars.length ? bars[0].Name : '';

// do similar for `Property`

return {
ID: foo.ID,
Name: name,
......
};
});

这也可以修改为具有一些实用函数,例如 getNameFromBars()并输入 $.grep在那里并返回找到的值或默认值。

如果你想摆脱 jQuery,你可以使用 Array.prototype.map()Array.prototype.filter()替换$.map$.grep .

还有$filter可以用。

关于angularjs - $.grep 在匹配后返回属性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33049011/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com