2017-02-01 6 views
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} 
     /> 
    ); 
} 

ответ

0

Проблема заключалась в том, что

dataSource: this.ds.cloneWithRows(data.Search) 

должен быть

dataSource: this.state.dataSource.cloneWithRows(tutorials) 

внутри onAfterLoad() метод.

Смежные вопросы