簡體   English   中英

Aurelia - repeat.for json

[英]Aurelia - repeat.for json

我是Aurelia的新手。

我試圖通過一些看起來如下的json迭代(repeat.for)。 我可以用手動連續這樣做,但藝術家的數量是可變的。 以下為例如作品。

         return this.http.fetch(baseUrl + "/artists/" + token + "&search=" + searchCreator)
        .then(response => response.json())
        .then(response => {
            //for (var i = 0; i < response.resultsCount; i++){              
            //    response += response.artists[i].objects;               
            //}
            return response.artists[0].objects.concat(response.artists[1].objects);
        });

如何為所有藝術家返回所有對象? 我試過用for循環這樣做但我無法讓它工作。 我應該返回response.artists,然后在我的視圖模型中使用它嗎? 這就是視圖的樣子:

    <tr repeat.for="item of items">
      <td>${item.title}</td>
      <td>${item.displayName}</td>
      <td>${item.objectNumber}</td>       
    </tr>

json示例:

{

"source": "My Museum",
"language": "EN",
"resultsCount": ​58,
"artists": 

[{

"artistID": ​47171,
"alphaSort": "Smith Eloise Vega",
"displayName": "Eloise Vega Smith",
"beginDate": "0",
"endDate": "0",
"displayDate": "",
"sex": "Female",
"nationality": "",
"objectCount": ​1,
"objects": 

[{
        "objectNumber": "209.2015",
        "objectID": ​188963,
        "title": "Album cover for Urszula Dudziak, Newborn Light",
        "displayName": "Eloise Vega Smith",
        "alphaSort": "Smith Eloise Vega",
        "artistID": ​47171,
        "displayDate": "",
        "dated": "1974",
        "dateBegin": ​1974,
        "dateEnd": ​1974,
        "medium": "Lithograph",
        "dimensions": "12 1/2 x 12 1/4\" (31.8 x 31.1 cm)",
        "department": "Architecture & Design",
        "classification": "A&D Graphic Design",
        "onView": ​0,
        "provenance": "",
        "description": "",
        "objectStatusID": ​1,
        "creditLine": "Committee on Architecture and Design Funds",
        "imageID": "502407",
        "thumbnail": "http:///TMSImages/Size1/Images/TR15211_10_RICR.jpg",
        "fullImage": "http:///TMSImages/Size3/Images/TR15211_10_RICR.jpg",
        "lastModifiedDate": "2015-09-17T01:00:08"
    }
]

},
{

"artistID": ​5479,
"alphaSort": "Smith Charles",
"displayName": "Charles Smith",
"beginDate": "1893",
"endDate": "1987",
"displayDate": "American, 1893–1987",
"sex": "Male",
"nationality": "American",
"objectCount": ​6,
"objects": 

[{

"objectNumber": "369.1941",
"objectID": ​67911,
"title": "Red Circle",
"displayName": "Charles Smith",
"alphaSort": "Smith Charles",
"artistID": ​5479,
"displayDate": "American, 1893–1987",
"dated": "1940",
"dateBegin": ​1940,
"dateEnd": ​1940,
"medium": "Monoprint",
"dimensions": "Sheet 21 1/8 x 14 3/4\" (53.8 x 37.5 cm) Comp.  20 x 14 3/4\" (50.8 x 37.5 cm)",
"department": "Prints & Illustrated Books",
"classification": "Print",
"onView": ​0,
"provenance": "",
"description": "Color monoprint, printed from movable forms",
"objectStatusID": ​1,
"creditLine": "Purchase",
"imageID": "260293",
"thumbnail": "http:///TMSImages/Size1/Images/369_1941_RICR.jpg",
"fullImage": "http:///TMSImages/Size3/Images/369_1941_RICR.jpg",
"lastModifiedDate": "2015-03-31T01:06:18"

},
{

"objectNumber": "214.1942",
"objectID": ​64517,
"title": "Abstraction",
"displayName": "Charles Smith",
"alphaSort": "Smith Charles",
"artistID": ​5479,
"displayDate": "American, 1893–1987",
"dated": "c. 1942",
"dateBegin": ​1942,
"dateEnd": ​1942,
"medium": "Woodcut",
"dimensions": "composition (irreg.): 11 1/4 x 3 3/4\" (28.5 x 9.6 cm); sheet: 14 9/16 x 7 1/16\" (37 x 17.9 cm)",
"department": "Prints & Illustrated Books",
"classification": "Print",
"onView": ​0,
"provenance": "",
"description": "Woodcut, printed in black, dark green yellow, deep blue and strong red brown",
"objectStatusID": ​1,
"creditLine": "Given anonymously",
"imageID": "195213",
"thumbnail": "http:///TMSImages/Size1/Images/214_1942_RICR.jpg",
"fullImage": "http:///TMSImages/Size3/Images/214_1942_RICR.jpg",
"lastModifiedDate": "2014-09-19T01:05:22"

},
etc.....

我很感激幫助!

如果您熟悉LINQ,可以使用類似jslinq的庫並執行以下操作:

return jslinq(response.artists)
    .selectMany(function(artist){
        return artist.objects
    }).toList();

當然,如果我打算在項目中多次使用它,我只會包含jslinq。 如果您不想要開銷,那么使用concat的解決方案應該可以正常工作:

var result = [];
for(var i = 0; i < response.artists.length; i++) {
    result = result.concat(response.artists[i].objects);
}
return result;

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM