首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用useFocusEffect钩子获取数据?

如何使用useFocusEffect钩子获取数据?
EN

Stack Overflow用户
提问于 2020-04-11 05:54:15
回答 1查看 3.1K关注 0票数 1

我是个新手,刚升级到react-navigation-5

我正在努力用新的钩子useFocusEffect替换旧的useFocusEffect函数

下面是旧的功能:

代码语言:javascript
复制
const loadTrips = useCallback(async() => {
        setError(null);
        setIsRefreshing(true);
        try {
            dispatch(tripActions.fetchTrip());
        } catch (error) {
            console.log(error);
            setError(error.message);
        }
        setIsRefreshing(false);
    },[dispatch, setIsRefreshing, setError]);
*********************************************************
// This is the old function
    useEffect(() => {
        const willFocus = props.navigation.addListener(
            'willFocus',
            loadTrips
        );
        return () => {willFocus.remove();}
    },[loadTrips]);
*********************************************************

    useEffect(() => {
        setIsLoading(true);
        loadTrips().then(
            setIsLoading(false),
        );
    }, [dispatch, loadTrips])

编辑1

我试图将loadtrips函数传递给useFocusEffect,但它显示了错误

代码语言:javascript
复制
useFocusEffect(loadTrips) 

请帮助

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-11 06:17:42

您可以简单地将loadTrips函数传递给useFocusEffect

代码语言:javascript
复制
const loadTrips = useCallback(async() => {
        setError(null);
        setIsRefreshing(true);
        try {
            dispatch(tripActions.fetchTrip());
        } catch (error) {
            console.log(error);
            setError(error.message);
        }
        setIsRefreshing(false);
    },[dispatch, setIsRefreshing, setError]);
useFocusEffect(useCallback(() => loadTrips(), [dispatch, setIsRefreshing, setError]));
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61152676

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档