在AngularJS

时间:2016-05-05 08:14:07

标签: javascript angularjs json onsen-ui monaca

我有一个在AngularJS,Onsen UI和Monaca中开发的跨平台应用程序。

在我的一个页面上,我进行了一次API调用,返回一个嵌套的JSON对象给我。我可以使用$ http.get()读取JSON对象,我可以遍历JSON并显示高级项目,但我似乎无法显示嵌套项目。

我想要做的是将高级项目显示为文本字段,然后将嵌套项目显示为每个高级项目的单选按钮。

我的JSON文件的示例如下所示:

[{
    "itemID": "1",
    "itemDescription": "Apple",
    "options": [{
        "fruitCheckID": "1",
        "fruitDescription": "Ok"
    }, {
        "fruitCheckID": "2",
        "fruitDescription": "Not Ripe"
    }, {
        "fruitCheckID": "3",
        "fruitDescription": "Rotten"
    }]
}, {
    "itemID": "2",
    "itemDescription": "Orange",
    "options": [{
        "fruitCheckID": "1",
        "fruitDescription": "Ok"
    }, {
        "fruitCheckID": "2",
        "fruitDescription": "Not Ripe"
    }, {
        "fruitCheckID": "3",
        "fruitDescription": "Rotten"
    }]
}]

在我的 fruit.html 页面中,我想将水果名称(itemDescription)显示为带有单选按钮的文本字段,用于每个" fruitDescription"项目

我的 fruit.html 页面如下所示:

<ul class="list">
    <li class="list__item" ng-repeat="checkItemDescription in data">
        <span class="list__item__line-height"><strong>{{checkItemDescription.itemDescription}}</strong></span>  <!-- WORKING HERE -->

        <label class="checkbox">
            <input type="checkbox"
                ng-click="toggleSelection(checkItemDescription.itemDescription)">
            <div class="checkbox__checkmark"></div>
            {{checkItemDescription.options}}  <!-- NOT WORKING HERE -->
        </label>
    </li>
</ul>

当我运行上面的内容时,我可以根据需要在列表中显示水果名称,但是对于每个水果项目,只显示1个单选按钮,然后是 JSON格式的代码 例如

  • Apple
  • (此处仅显示1个单选按钮)
  • [{&#34; fruitCheckID&#34;:&#34; 1&#34;,&#34; fruitDescription&#34;:&#34; Ok&#34; },{&#34; fruitCheckID&#34;:&#34; 2&#34;,&#34; fruitDescription&#34;:&#34;不成熟&#34; },{&#34; fruitCheckID&#34;:&#34; 3&#34;,&#34; fruitDescription&#34;:&#34;腐烂&#34; }]

该列表中的第3个项目符号点实际上是如何向我显示项目。

在我的 app.js 中,我得到了如下的JSON对象,当我在console.log()时,它的所有JSON对象都应该显示。

// Loop through the JSON [object Object]...[object Object] returned from API call
angular.forEach($scope.data, function(value, key)
{   
    // WORKING
    console.log("Item ID: " + value.itemID);
    console.log("Item Description: " + value.itemDescription);

    // Inner loop to return nested JSON objects
    angular.forEach(value.options, function(v, k)
    {
        // WORKING
        console.log("Fruit Check ID: " + v.fruitCheckID);
        console.log("Fruit Description: " + v.fruitDescription);
    });
});

有人能告诉我显示嵌套值的格式出错吗?

1 个答案:

答案 0 :(得分:0)

尝试使用此代码..

 <ul class="list">
<li class="list__item" ng-repeat="checkItemDescription in data">
    <span class="list__item__line-height"><strong>   {{checkItemDescription.itemDescription}}</strong></span>  <!-- WORKING HERE -->

    <label class="checkbox">
        <input type="checkbox"
            ng-click="toggleSelection(checkItemDescription.itemDescription)">
        <div class="checkbox__checkmark" ng-repeat="options in data.options "></div><!-- use ng-repeat here -->
        {{options.fruitDescription}}  
    </label>
</li>