2

嗨,我是 Angular 新手,只是想学习如何做一些事情。我一直在尝试显示以下数据。使用适用于 chrome 的 Batarang 插件,我可以看到我的宁静 Web 服务返回以下 json,该 json 被包装到我的模型中。

    { 
    course:  { 
        country: Test1
        numberEnrolledPerMonthPerWeek:  { 
            entry: 
            [  { 
                key: 2
                value:  { 
                    numberEnrolled: 0
                    weeks: 2
                    year: 2011
                } 
            } ,  { 
                key: 3
                value:  { 
                    numberEnrolled: 4
                    weeks: 3
                    year: 2011
                } 
            } ,  { 
                key: 4
                value:  { 
                    numberEnrolled: 6
                    weeks: 4
                    year: 2011
                } 
            } ,  { 
                key: 8
                value:  { 
                    numberEnrolled: 0
                    weeks: 8
                    year: 2011
                } 
            }  
            ]
        } 
    } 
 } 

我正在尝试将每个键的 numberEnrolled 值取出到一列中。所以在我的html中,我有以下内容

<table class="table table-striped table-bordered">
            <tr ng-repeat="course in enrolledcourses.enrolledEnrolment">
                <td>                                
                    {{course.country}}
                </td>   
                <td>
                    {{course.numberEnrolledPerMonthPerWeek[2].numberEnrolled}}
                </td>               
            </tr>   
        </table>

{{course.numberEnrolledPerMonthPerWeek[2].numberEnrolled}} 没有返回任何值,所以任何人都可以告诉我获取 numberEnrolled 值的正确语法是什么。

我努力了

{{course.numberEnrolledPerMonthPerWeek.2.numberEnrolled}}
{{course.numberEnrolledPerMonthPerWeek[2][numberEnrolled]}}

我的控制器代码如下

.controller('PeopleCtrl', function($scope, recruitmentFactory) {
    $scope.enrolledcourses = recruitmentFactory.get();


    $scope.test = "hello";
    $scope.save = function() {
        alert("save has been called");
    };
})
4

4 回答 4

2

首先,您的 JSON 有很多错误。也许这只是你得到的输出,但以防万一:: 缺少逗号并且 Test 是一个符号,但我想它是一个字符串。

$scope.enrolledcourses = {
    course : {
    country: 'Test1',
    numberEnrolledPerMonthPerWeek: {
        entry: [{
            key: 2,
            value: {
                numberEnrolled: 0,
                weeks: 2,
                year: 2011,
            }
        }, {
            key: 3,
            value: {
                numberEnrolled: 4,
                weeks: 3,
                year: 2011
            }
        }, {
            key: 4,
            value: {
                numberEnrolled: 6,
                weeks: 4,
                year: 2011
            }
        }, {
            key: 8,
            value: {
                numberEnrolled: 0,
                weeks: 8,
                year: 2011
            }
        }]
    }
    }
};

那么您的 html 需要访问正确的属性:

    <tr ng-repeat="course in enrolledcourses">
        <td>{{course.country}}</td>
        <td>{{course.numberEnrolledPerMonthPerWeek.entry[2].value.numberEnrolled}}</td>
    </tr>

这是一个活生生的例子

于 2013-10-22T14:40:56.850 回答
1

只是为了提供一些额外的帮助:我在弄清楚如何浏览 JSON 数据时经常遇到这个问题。尝试使用可视化工具,并验证您的 JSON 以确保其正确。

这是我用来可视化数据的方法:http: //jsonviewer.stack.hu/ 这里的验证:http: //jsonlint.com/

于 2013-12-31T18:37:28.060 回答
0
numberEnrolledPerMonthPerWeek[2] is not your array

尝试

numberEnrolledPerMonthPerWeek.entry[2]
于 2013-10-22T14:30:26.403 回答
0

好的,所以我做了以下操作来获取价值

{{course.numberEnrolledPerMonthPerWeek.entry[2].value.numberEnrolled}}  
于 2013-10-22T14:38:38.277 回答