异步后端调用上的useEffect和setState不重新呈现组件

时间:2020-02-25 23:01:32

标签: react-native react-hooks expo

我们有一个cardList react本机组件,它是搜索组件的子组件。

export default function CardList(props) {

  keyExtractor = (item, index) => index.toString()

  renderItem = ({ item }) => (
      <ListItem
        title={item.name}
        subtitle={item.subtitle}
        leftAvatar={{
          source: item.avatar_url && { uri: item.avatar_url },
          title: item.name[0]
        }}
        bottomDivider
        chevron
      />
  )

  return (
    <FlatList
      keyExtractor={keyExtractor}
      data={props.images}
      renderItem={renderItem}
    />
  );
}

搜索从后端获取异步数据,这需要花费几秒钟的时间,并且通过useEffect完成,出于某种原因,useEffect中的setKeys不会重新呈现cardList组件。当我在博览会上使用热重装进行人为刷新时,cardList呈现良好。为什么setKeys(useState)无法呈现组件?

感谢您的帮助!

  const [keys, setKeys] = useState([]);
  useEffect(() => {
    const fetchData = async () => {
      const imgkeys = await << 5 second long backend call >>;
      setKeys(imgkeys);
    }
    fetchData();
  }, []);
  return (
    <View>
      <View style={{
        padding: 5,
         }}>  
        { (keys) && (keys.length>0) && <CardList images={keys}/> }
      </View>
    </View>
  );

1 个答案:

答案 0 :(得分:0)

setState出于性能原因是异步的,不应仅由于状态更新未正确执行而被迫同步。

您可以像这样简单地定义useState:

const [, forceUpdate] = React.useState(0);
forceUpdate(n => !n)