0
Я пытаюсь отобразить json (массив объектов фильмов), прочесть компонент ListView, но получить ошибку: не может прочитать свойство cloneWithRows неопределенного. Что именно я делаю неправильно? Я нашел много учебников, и все они используют жестко кодированные данные и не могут видеть, как они используются, когда данные поступают из запроса. Вот мой код:Отображение json в ListView
constructor() {
super();
const ds = new ListView.DataSource({ rowHasChanged: (r1, r2) => r1 !== r2 });
this.state = { dataSource: ds.cloneWithRows([]) };
}
componentWillMount() {
axios.get('https://www.omdbapi.com/?s=Batman&page=2')
.then(response => response.data)
.then(this.onAfterLoad)
.catch(this.manageError);
}
// We will update the state of the application so that images can render
onAfterLoad = (data) => {
this.setState({ dataSource: this.ds.cloneWithRows(data.Search) });
};
// If there is an error show error
manageError = (error) => {
Alert.alert('Failure fetching data');
console.error(error);
};
// Description: Render all the titles
// ------------------------------------------------------------------------------------
renderRow(rowData) {
console.log(rowData);
return <Movie key={rowData.imdbID} data={rowData} />;
}
// Description: Render everything to the screen
// ------------------------------------------------------------------------------------
render() {
return (
<ListView
dataSource={this.state.dataSource}
renderRow={this.renderRow}
/>
);
}