简体   繁体   English

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

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

I'm new to React-Native, therefore, Javascript and I'm trying to understand how I can retrieve this data to be filled in my FlatList. 我是React-Native的新手,因此,我想了解如何才能检索要填充到FlatList中的数据。 The JSON format I receive looks like this 我收到的JSON格式如下所示

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

Here's what my FlatList looks like 这是我的FlatList的样子

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

If the format is like this, my FlatList is working well 如果格式是这样,我的FlatList工作正常

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

My question is: how can I manage to use the first format by looping through each item and ignoring the first id (for example "18" in the first example) so that I can use item.keyName in my FlatList to display each values? 我的问题是:如何通过遍历每个项目并忽略第一个ID(例如第一个示例中的“ 18”)来设法使用第一种格式,以便可以在FlatList中使用item.keyName显示每个值? It seems like I need to get the nested element but I can't figure out how to do this. 似乎我需要获取嵌套元素,但我不知道如何执行此操作。

And if needed, this is how I fetch my data 如果需要,这就是我获取数据的方式

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

Thanks! 谢谢!

By using Object.keys and Array.map we can get the data to look like you want. 通过使用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) 

After this, dataArray will look like [{keyName: 18, sizeQualifierName: "gr.20", ...}, {keyName: 19, sizeQualifierName:"gr.18-20", ...}] 此后,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