Unlike ListView we can update this.state.datasource. Is there any method or example to update FlatList or re-render it?
My goal is to update the text value when user press button ...
renderEntries({ item, index }) {     return(         <TouchableHighlight onPress={()=> this.setState({value: this.state.data[index].value+1})>              <Text>{this.state.data[index].value}</Text>         </TouchableHighlight>     ) }  <FlatList      ref={(ref) => { this.list = ref; }}      keyExtractor={(item) => item.entry.entryId}      data={this.state.data}      renderItem={this.renderEntries.bind(this)}      horizontal={false} /> To implement pull to refresh FlatList with React Native, we can set the refreshing and onRefresh props. to set the refreshing prop to isFetching , which is true when we're getting data for the FlatList . And we set onRefresh to the onRefresh which sets refreshing to true and then set it back to false after 2 seconds.
You can force flatlist to rerender by passing the updated list as an extraData prop, i.e extraData={listData} . However, when using functional components a common mistake is passing the same instance of the list data as the prop.
React Native RefreshControl If you're rendering a list of data using the ScrollView or FlatList component, you can use RefreshControl to add the pull-to-refresh capability. When you initiate the pull-to-refresh gesture, RefreshControl triggers an onRefresh event.
By passing extraData={selectedId} to FlatList we make sure FlatList itself will re-render when the state changes. Without setting this prop, FlatList would not know it needs to re-render any items because it is a PureComponent and the prop comparison will not show any changes.
Use the extraData property on your FlatList component.
As the documentation states:
By passing
extraData={this.state}toFlatListwe make sureFlatListwill re-render itself when thestate.selectedchanges. Without setting this prop,FlatListwould not know it needs to re-render any items because it is also aPureComponentand the prop comparison will not show any changes.
For quick and simple solution Try:
set extra data to a boolean value.
extraData={this.state.refresh}
Toggle the value of boolean state when you want to re-render/refresh list
this.setState({      refresh: !this.state.refresh }) If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With