最近在项目中发现了一个问题,在使用useState修改值之后,拿不到修改后的值,能肯定的是肯定修改了,不然页面会空白,但是拿不到数据,就很无奈。
最后发现,函数式组件使用useState设置值的方法也是一个异步的方法,而直接输出是同步的,但是还是拿不到值
这个加上await之后保证fectchData函数执行完成之后在输出,应该就会有值,但是输出还是{}
无奈发现,useEffect里面的立即执行函数只会执行一次,因为第二个参数是空数组,导致它没有监听任何数据的值,就相当于类式组件中的componentDidMount钩子,因此只会执行一次
修改代码为:
useEffect( () => {
fetchData()
},[])
useEffect(() => {
// 监听cityArr的值,第一次肯定为{},等到它有数据之后,在输出
if(Object.keys(cityArr).length !== 0){
console.log(cityArr);
listRef.current.measureAllRows()
}
},[cityArr])
如此,就解决了拿不到数据的问题