如何立即更新呈现的 flat/section 列表项 React Native
How to update rendered flat/section list items immediately React Native
我正在创建一个 ContactListScreen
。 ContactListScreen
的直接子节点是 ContactItems
,ContactItems
是一个呈现每个 ContactItem
的 sectionList。
但是问题出现了,因为我的 ContactItems
应该是 multi-selectable.
我将 selectedContacts
的数组从我的州传递给每个 ContactItem
。我这里使用的逻辑是 ContactItem
检查 selectedContacts
的长度是否为 0。如果长度为零,它不应该呈现任何 selectItemView
,如果我 select 一个项目,它应该使用回调将自己推送到 selectedContacts
。但问题是子组件 (ContactItem
) 在我 selected deselect 两次或三次之前不会更新。我怎样才能让它发挥作用?
ContactList.tsx
的一部分
class ContactList extends Component {
this.state = {
loading: false,
error: null,
data: [],
selectedItems: []
};
handleSelectionPress = (item) => {
this.setState(prevState => {
const { selectedItems } = prevState;
const isSelected = selectedItems.includes(item);
return {
selectedItems: isSelected
? selectedItems.filter(title => title !== item)
: [item, ...selectedItems],
};
});
};
renderItem(item: any) {
return <ContactItem item={item.item}
isSelected={this.state.selectedItems.includes(item.item)}
onPress={this.handleSelectionPress}
selectedItems={this.state.selectedItems}
/>;
}
render() {
return (
<View style={styles.container}>
<SectionList
sections={this.state.data}
keyExtractor={(item, index) => item.id}
renderItem={this.renderItem.bind(this)}
renderSectionHeader={({section}) => (
section.data.length > 0 ?
<Text>
{section.title}
</Text> : (null)
)}
/>
</View>
);
}
}
ContactItem.tsx
的一部分
class ContactItem extend Component {
render() {
const checkBox = <TouchableOpacity onPress={() => {
this.props.onPress(this.props.item)
}
} style={this.props.selectedItems.length > 0 && {display: 'none'}}>
{!this.props.isSelected ?
<View style={{borderRadius: 10, height: 20, width: 20, borderColor: "#f0f", borderWidth: 1}}>
</View> : <View style={{
borderRadius: 10,
height: 20,
width: 20,
borderColor: "#f0f",
borderWidth: 1,
backgroundColor: "#f0f"
}}>
</View>}
</TouchableOpacity>
return (
<View style={this.styles.contactsContainer}>
<TouchableOpacity
onLongPress={() => this.props.onPress(this.props.item)}>
<View style={this.styles.contactInfo}>
{checkBox}
</View>
</TouchableOpacity>
</View>
);
}
注意:我工作的地方没有使用功能组件。
我对此不是 100% 确定,但我感觉问题是 SectionList
组件没有触发其更新,因为提供的 sections={this.state.data}
属性 永不改变。
处理此问题的最简单方法是将 selectedItems
作为 extraData 属性 添加到部分列表:
<SectionList
sections={this.state.data}
extraData={this.state.selectedItems}
//...
我正在创建一个 ContactListScreen
。 ContactListScreen
的直接子节点是 ContactItems
,ContactItems
是一个呈现每个 ContactItem
的 sectionList。
但是问题出现了,因为我的 ContactItems
应该是 multi-selectable.
我将 selectedContacts
的数组从我的州传递给每个 ContactItem
。我这里使用的逻辑是 ContactItem
检查 selectedContacts
的长度是否为 0。如果长度为零,它不应该呈现任何 selectItemView
,如果我 select 一个项目,它应该使用回调将自己推送到 selectedContacts
。但问题是子组件 (ContactItem
) 在我 selected deselect 两次或三次之前不会更新。我怎样才能让它发挥作用?
ContactList.tsx
的一部分class ContactList extends Component {
this.state = {
loading: false,
error: null,
data: [],
selectedItems: []
};
handleSelectionPress = (item) => {
this.setState(prevState => {
const { selectedItems } = prevState;
const isSelected = selectedItems.includes(item);
return {
selectedItems: isSelected
? selectedItems.filter(title => title !== item)
: [item, ...selectedItems],
};
});
};
renderItem(item: any) {
return <ContactItem item={item.item}
isSelected={this.state.selectedItems.includes(item.item)}
onPress={this.handleSelectionPress}
selectedItems={this.state.selectedItems}
/>;
}
render() {
return (
<View style={styles.container}>
<SectionList
sections={this.state.data}
keyExtractor={(item, index) => item.id}
renderItem={this.renderItem.bind(this)}
renderSectionHeader={({section}) => (
section.data.length > 0 ?
<Text>
{section.title}
</Text> : (null)
)}
/>
</View>
);
}
}
ContactItem.tsx
的一部分class ContactItem extend Component {
render() {
const checkBox = <TouchableOpacity onPress={() => {
this.props.onPress(this.props.item)
}
} style={this.props.selectedItems.length > 0 && {display: 'none'}}>
{!this.props.isSelected ?
<View style={{borderRadius: 10, height: 20, width: 20, borderColor: "#f0f", borderWidth: 1}}>
</View> : <View style={{
borderRadius: 10,
height: 20,
width: 20,
borderColor: "#f0f",
borderWidth: 1,
backgroundColor: "#f0f"
}}>
</View>}
</TouchableOpacity>
return (
<View style={this.styles.contactsContainer}>
<TouchableOpacity
onLongPress={() => this.props.onPress(this.props.item)}>
<View style={this.styles.contactInfo}>
{checkBox}
</View>
</TouchableOpacity>
</View>
);
}
注意:我工作的地方没有使用功能组件。
我对此不是 100% 确定,但我感觉问题是 SectionList
组件没有触发其更新,因为提供的 sections={this.state.data}
属性 永不改变。
处理此问题的最简单方法是将 selectedItems
作为 extraData 属性 添加到部分列表:
<SectionList
sections={this.state.data}
extraData={this.state.selectedItems}
//...