javascript - 如何在 React-Native 上使用嵌套 JSON 填充平面列表

标签 javascript json react-native

我是 React-Native 的新手,因此,Javascript,我正在尝试了解如何检索要填充到我的 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", ... }]

关于javascript - 如何在 React-Native 上使用嵌套 JSON 填充平面列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49305705/

相关文章:

ios - 检测 TouchableWithoutFeedback 长新闻稿

javascript - 如何自定义嵌套组件?

javascript - 使用 Javascript 或 Jquery 附加 Html

javascript - 使用动态字段名称更新数据

MySQL JSON 列前置对象

android - 如何从服务器接收回 JSON 数据?

javascript - JSON验证

ios - React Native FBSDK 登录 - 使用应用程序登录失败

javascript - CSS 中的字体大小不起作用

javascript - RGB 到颜色名称映射(近似颜色映射)