1

我的目标是快速创建一个标签,显示与给定出版物相关的所有作者。

$scope.publications.authors当设置为单个值时,一切正常。当多个值存储在数组中时,它们不起作用,如下所示。

我知道 AngularJS ngShow 指令的条件语句不适用于数组,但我似乎无法弄清楚我实际上应该使用什么。

HTML:

<div ng-repeat="person in persons" ng-show="person.firstName == publication.authors">{{person.firstName}}</div>

JS:

$scope.publications = [
{"title": "Research Paper",
 "authors": ["Bill", "George"]};

$scope.persons = [
{"firstName": "Bill",
 "lastName": "Smith"},
{"firstName": "George",
 "lastName": "Jones"},
{"firstName": "Mike",
 "lastName": "Thomas"};
4

3 回答 3

2

在您的控制器中创建函数,该函数可以检查元素是否存在persons并在您的ng-show. 检查下面的小提琴:

http://jsfiddle.net/HB7LU/323/

于 2013-08-15T23:32:50.090 回答
2

根据 的数据结构publications,需要一个嵌套中继器。您可以使用带有电流personpublication传入的函数来驱动显示器。

<div ng-repeat="publication in publications">{{publication.title}}
    <br/>
    <div ng-repeat="person in people" ng-show="show(person, publication)">{{person.firstName}}</div>
</div>

function ctrl($scope) {
    $scope.publications = [{
        "title": "Research Paper",
            "authors": ["Bill", "George"]
    }];

    $scope.people = [{
        "firstName": "Bill",
            "lastName": "Smith"
    }, {
        "firstName": "George",
            "lastName": "Jones"
    }, {
        "firstName": "Mike",
            "lastName": "Thomas"
    }];

    $scope.show = function (person, publication) {
        return publication.authors.indexOf(person.firstName) >= 0;
    }
}
于 2013-08-16T00:17:14.087 回答
0

我认为最好的方法是在控制器中使用方法,而不是尝试迭代 DOM 中的所有数据。

使用方法有多种方法可以做到这一点。如果您只想在 1 行上显示所有作者的姓名,您可以有一个方法来获取作者并返回一个包含所有姓名的字符串,并使用此方法参考此方法以获取 div 的内容

{{getAuthors(publication.authors}}

您还可以有一个方法返回名称数组并使用类似这样的 ng-repeat 对其进行迭代

于 2013-08-15T23:35:44.180 回答