Я хочу обновить данные для одного из дочерних элементов представления вкладок без повторного рендеринга всего представления вкладок в реагировать на родной.component.
state = {
Downloading: false,
RealSlider: 1,
svalue: 1,
appState: AppState.currentState,
selectedValue: 0,
SelectedAuthorArrayIndex: 0,
Authors: [],
index: 0,
routes: [],
loading: true,
innerLoading: true,
M1TurnMeOn: false,
M2TurnMeOn: false,
Playing: false,
AudioPicked: false,
currentTime: "00:00",
currentAudioDuration: 0,
currentAudioName: "",
currentAudioAuthor: "",
currentAudioID: "0",
currentAudioURL: "",
currentAudiono: "0",
currentIntro: "",
currentAudioDownload: 0
};
_renderTabBar = props => {
return (
<TabBar
{...props}
scrollEnabled
indicatorStyle={styles.indicator}
style={styles.tabbar}
labelStyle={styles.label}
tabStyle={{ paddingVertical: "2.5%" }}
/>
);};
_keyExtractor = (item, index) => "GRID" + index;
_renderTabScreen = ({ route }) => {
return (
<View style={[styles.page, { backgroundColor: "#673ab7" }]}>
<FlatList
keyExtractor={this._keyExtractor}
data={route.DATA}
renderItem={this._renderFlatlistItem}
style={StyleA.list}
/>
</View>
);
};
_renderFlatlistItem = ({ item, index }) => {
return (
<View style={StyleA.AudioItem} key={index}>
<View style={StyleA.AudioView}>
<TouchableWithoutFeedback
onPress={() => this.DoItForclickOnBoardItem(item)}
>
<View style={StyleA.AudioViewLeft}>
<ICON1 name="play" color="#68D0FE" size={50} />
</View>
</TouchableWithoutFeedback>
<View style={StyleA.AudioViewRight}>
<View style={StyleA.AudioViewRightLeft}>
<Text style={StyleA.AudioNameText}>{item.name}</Text>
<Text style={StyleA.AudioAuthorNameText}>
{
this.state.Authors[this.state.SelectedAuthorArrayIndex]
.authorname
}
</Text>
</View>
<View style={StyleA.AudioViewRightRight}>
{item.isdownloaded != 2 && (
<TouchableOpacity
onPress={() =>
this.DownloadfromTheList(
item.content_id,
item.content_no,
item.name,
this.type,
item.URL
)
}
>
<Image
source={downloadIcon}
style={StyleA.downloadIcon2}
resizeMode={"stretch"}
/>
</TouchableOpacity>
)}
</View>
</View>
</View>
</View>
);
};
render(){
.
.
.
{!this.state.AgainLoading && (
<TabView
style={styles.TabView}
onIndexChange={index => this.setState({ index })}
navigationState={this.state}
initialLayout={initialLayout}
renderScene={this.__renderTabScreen}
renderTabBar={this._renderTabBar}
canJumpToTab={() => {
return true;
}}
/>
)}
.
.
.
}
Мой код работает, как и ожидалось, но я хочу, чтобы был способ обновить элемент Flatlist одного экрана Tab View, без повторного рендеринга всего компонента Tab View.