javascript - 如何从反应原生 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
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
)}
}}
/>
解决方案
您不能像这样从 render 方法启动异步操作(例如从 Firestore 加载数据)。你应该:
- 在 render 方法之外启动异步操作。
- 当您从该操作中获得结果时,将其置于组件的状态。
- 这将触发组件的重新渲染,其中 render 方法可以从状态中获取数据。
在此处查看我的答案以获取示例:React Not Updating Render After SetState
推荐阅读
- javascript - 如何处理“未检查的 runtime.lastError:消息端口在收到响应之前关闭”?
- c# - 在不使用 DTE 的情况下访问构建事件
- git - 从 fork 到上游的 Git 独立提交
- maven - Fabric8:使用外部 pod 部署 java 应用程序
- python - 只能将一个结果写入 csv 文件
- web-scraping-language - 网页抓取语言:如何进行分页抓取?
- c# - 同时流式传输来自不同客户端的大数据
- sql-server - 自动为 SELECT 语句中的所有列生成别名
- scala - 有没有办法使伴生对象函数私有并将伴生对象导入类然后访问该函数?
- javascript - express.js“next()”参数的确切性质