xgqfrms™, xgqfrms® : xgqfrms's offical website of cnblogs! xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!

react hooks useEffect 取消 promise

react hooks useEffect 取消 promise

cancel promise

https://github.com/facebook/react/issues/15006#issuecomment-543059930

https://react.docschina.org/docs/hooks-effect.html#需要清除的-effect

https://overreacted.io/zh-hans/a-complete-guide-to-useeffect/

清除的 effect & 取消订阅 & 取消 promise

bug

OK


  const { adcode, regions = [] } = regionData;
  const [regionName, setRegionName] = useState('全国');
  const [tableData, setTableData] = useState(regions);
  useEffect(() => {
    let isSubscribed = true;
    // getRegionName(adcode).then(setRegionName);
    getRegionName(adcode).then(() => {
      if(isSubscribed) {
        return setRegionName;
      }}
    );
    // 添加name字段
    const promises = [];
    regions.forEach(item => {
      promises.push(
        getRegionName(item.code)
        .then(name => {item.name = name;})
        // eslint-disable-next-line no-console
        .catch(() => console.log('获取%s地名失败', item.code)),
      );
    });
    // 后端传来部分区划代码是错误的,找不到对应地名,暂时先剔除
    Promise
    .all(promises)
    .then(() => {
      if(isSubscribed) {
        return setTableData(regions.filter(({ name }) => !!name));
      }
    });
    return () => isSubscribed = false;
  }, [adcode, regionData, regions]);

https://juliangaramendy.dev/use-promise-subscription/

https://segmentfault.com/a/1190000018652589#articleHeader7

refs



©xgqfrms 2012-2020

www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

原创文章,版权所有©️xgqfrms, 禁止转载 🈲️,侵权必究⚠️!


posted @   xgqfrms  阅读(958)  评论(8编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2018-10-17 macOS & Python & Redis All In One
2018-10-17 PHP & LAMP & WAMP
2018-10-17 shit layui & select & re-render & bug
2018-10-17 Chrome new features
2018-10-17 pdf & background
点击右上角即可分享
微信分享提示