[英]How to render a function inside a FlatList for a specific element in React Native
[英]How to get value from another function inside react native flatList?
我正在尝试从被阻止的用户中过滤掉帖子。 接近它的最佳方法是什么? 因为状态更新使应用程序滞后。 这是我接近它的方式:
我做了一个功能来检查用户是否被阻止
checkBlocked = async userId => {
try {
let snapshot = await firebase.database().ref('Blocked/' + firebase.auth().currentUser.uid).orderByChild('uid').equalTo(userId).once('value')
return snapshot.exists();
}
catch(error) {
return false;
}
}
然后在 flatlist 中,我试图过滤来自一个已阻止的用户的帖子。
<FlatList
inverted
extraData={this.state.blocked}
data={this.state.arrData}
keyExtractor={item => item.key}
renderItem={({ item }) => {
this.checkBlocked(item.id).then(val => this.setState({blocked: val}));
if(this.state.blocked == true){
return (
//something )
}
else {
return (
//something
)}
}}
/>
您不能像这样从渲染方法启动异步操作(例如从 Firestore 加载数据)。 你应该:
请参阅我在此处的答案以获取示例: React Not Updating Render After SetState
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.