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

标签 angularjs multidimensional-array

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

尝试将两个数组映射在一起。一个数组包含 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/

相关文章:

angularjs - 在 Angular 接口(interface)中重用方法

c++ - 当我试图在 C++ 中访问这个数组 (2d) 时出了什么问题

java - 锯齿状阵列;检查列值增加

java - 修复 Java 中的空指针异常

java - 二维数组复制列和行,并证明包含是否等于

angularjs - ExpressJS 下使用 HTML5 url 模式的 AngularJS SEO

javascript - Bootstrap 选项卡内容/选项卡 Pane 上的 ng-repeat

javascript - AngularUI Router + Ionic - 路由可以在浏览器中工作,但不能在 Ionic View 中工作?

javascript - 消除 ng-keypress 的抖动

C 三维数组初始化