Я пытаюсь создать простую страницу, на которой я хочу отобразить данные, которые я получаю из файла Json. К сожалению, я получаю "Инвариантное нарушение: объекты недопустимы в качестве дочерних элементов React (найдено: объект с ключами {ts, trend, baro, temp, hum, wind, rain, et, прогноз, sun}). Если вы имели в виду чтобы отобразить коллекцию дочерних элементов, используйте вместо этого массив. "
Итак, он загружает Json, но я не могу отобразить данные. Если пробовал разные методы, но не смог решить.
App.js
import React from 'react'
import { AppRegistry, StyleSheet, FlatList, Text, View, Alert, ActivityIndicator, Platform} from 'react-native'
export default class Planner extends React.Component {
constructor(props)
{
super(props);
this.state = {
isLoading: true
}
}
componentDidMount() {
return fetch('url')
.then((response) => response.json())
.then((responseJson) => {
this.setState({
isLoading: false,
dataSource: responseJson
}, function() {
// In this block you can do something with new state.
});
})
.catch((error) => {
console.error(error);
});
}
FlatListItemSeparator = () => {
return (
<View
style={{
height: 1,
width: "100%",
backgroundColor: "#607D8B",
}}
/>
);
}
render() {
if (this.state.isLoading) {
return (
<View style={{flex: 1, paddingTop: 20}}>
<ActivityIndicator />
</View>
);
}
return (
<View>
data ={ this.state.dataSource }
renderItem={({item}) => <Text > {item.temp.out.c} </Text>}
keyExtractor={(item, index) => index}
</View>
);
}
}
Json
{
"ts": 1530290929,
"trend": {
"val": -20,
"text": "langsam fallend"
},
"baro": 1010.4310482000001,
"temp": {
"out": {
"f": 85.9,
"c": 29.9
}
},
"hum": {
"out": 29
},
"wind": {
"speed": {
"mph": 5,
"kmh": 8
},
"avg": {
"mph": 3,
"kmh": 4.8
},
"dir": {
"deg": 58,
"text": "ONO"
}
},
"rain": {
"rate": 0,
"storm": 0,
"day": 0,
"month": 100.33,
"year": 451.358
},
"et": {
"day": 176,
"month": 480,
"year": 1673
},
"forecast": {
"val": 6,
"rule": 45,
"text": "Zunehmend wolkig bei gleichbleibender Temperatur."
},
"sun": {
"uv": 1.3,
"rad": 322,
"rise": "4:25",
"set": "20:37"
}
}
Заранее спасибо!