首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >响应useEffect清理功能取决于异步等待结果

响应useEffect清理功能取决于异步等待结果
EN

Stack Overflow用户
提问于 2019-07-19 15:30:21
回答 2查看 1.6K关注 0票数 2

我有一个react组件,它异步获取一些资源,然后订阅资源更改。

问题是,清理功能不是在关闭此资源:

代码语言:javascript
复制
useEffect(() => {
  const onResourceChange = () => { 
    console.log('resource changed');
  };

  getSomeResource().then(resource => {
    resource.subscribe(onResourceChange);
  });

  return () => {
    resource.unsubscribe(onResourceChange); // Error! resource is undefined
  }
}, []);

由于不允许在useEffect中使用异步函数,在useEffect的清理功能中取消订阅该资源的最佳方法是什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-07-19 15:49:10

我看到这里发生了两个“副作用”。

  1. 获取资源(需求只发生一次,依赖[])
  2. 订阅/取消订阅回调(需要在资源更改、依赖、[resource]上发生)

所以我

  1. 将它们分成两个“效果”(步骤,每个步骤处理一个副作用)
  2. 并将其提取到自定义钩子中。
代码语言:javascript
复制
    function useResource() {
        const [resource, setResource] = useState(undefined)

        const onResourceChange = () => console.log('resource changed');

        // Get the resource, initially.
        useEffect(() => {
          getSomeResource(setResource)
        }, [])

        // When the resource is retrieved (or changed),
        // the resource will subscribe and unsubscribe
        useEffect(() => {
          resource.subscribe(onResourceChange)
          return () => resource.unsubscribe(onResourceChange)
        }, [resource])
    }

    // Use it like this
    function App() {
        useResource()

        return <>your elements</>
    }

如您所见,第一个useEffect只负责获取“资源”,而第二个useEffect负责调用/订阅回调。

并查看每个useEffect中的useEffect列表(前者是空[],而后者依赖于[resource]__)

票数 4
EN

Stack Overflow用户

发布于 2019-07-19 15:34:17

这是一个解决方案,可能是丑陋的那个..。但仍然有一个解决办法:)

代码语言:javascript
复制
useEffect(() => {
    const onResourceChange = () => { 
        console.log('resource changed');
    };

    let data = {};

    getSomeResource().then(resource => {
        data.resource = resource;
        resource.subscribe(onResourceChange);
    });

    return () => {
        data.resource && data.resource.unsubscribe(onResourceChange); // Error! resource is undefined
    };
}, []);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57115559

复制
相关文章

相似问题

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