簡體   English   中英

如何在React-Native上使用嵌套JSON填充Flat List

[英]How to fill Flat List with nested JSON on React-Native

我是React-Native的新手,因此,我想了解如何才能檢索要填充到FlatList中的數據。 我收到的JSON格式如下所示

[
  {
    "18": {
      "sellingUnitName": "unité(s)",
      "qualifier": "GOOD",
      "sizeQualifierName": "gr.20"
    },
    "19": {
      "sellingUnitName": "unité(s)",
      "qualifier": "BAD",
      "sizeQualifierName": "gr.18-20"
    }
  }
]

這是我的FlatList的樣子

<FlatList
    data={ this.state.dataSource }
    ItemSeparatorComponent = {this.FlatListItemSeparator}
    renderItem={({item}) => <Text>{item.sellingUnitName}</Text>}
    keyExtractor={(item, index) => index.toString()}
/>

如果格式是這樣,我的FlatList工作正常

[
  {
    "sellingUnitName": "unité(s)",
    "qualifier": "GOOD",
    "sizeQualifierName": "gr.20"
  },
  {
    "sellingUnitName": "unité(s)",
    "qualifier": "BAD",
    "sizeQualifierName": "gr.18-20"
  }
]

我的問題是:如何通過遍歷每個項目並忽略第一個ID(例如第一個示例中的“ 18”)來設法使用第一種格式,以便可以在FlatList中使用item.keyName顯示每個值? 似乎我需要獲取嵌套元素,但我不知道如何執行此操作。

如果需要,這就是我獲取數據的方式

fetch('https://www.mywebsite.com/test.php')
  .then((response) => response.json())
  .then((responseJson) => {
      this.setState({
        dataSource: responseJson
      };
     })
   .catch((error) => {
       console.error(error);
   });

謝謝!

通過使用Object.keysArray.map我們可以使數據看起來像您想要的。

 let data = [ { "18": { "sellingUnitName": "unité(s)", "qualifier": "GOOD", "sizeQualifierName": "gr.20" }, "19": { "sellingUnitName": "unité(s)", "qualifier": "BAD", "sizeQualifierName": "gr.18-20" } } ]; let dataObj = data[0]; let dataArray = Object.keys(dataObj).map(key => { let obj = dataObj[key]; obj.keyName = key; return obj; }) console.log(dataArray) 

此后,dataArray將看起來像[{keyName: 18, sizeQualifierName: "gr.20", ...}, {keyName: 19, sizeQualifierName:"gr.18-20", ...}]

暫無
暫無

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

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