flutter取消Future.delayed

在Flutter开发中,使用Future.delayed进行延迟操作时,如果在等待期间离开页面,可能会导致已卸载的Widget尝试跳转,从而引发错误。解决方法是在dispose时取消Future,但发现Future.delayed内部使用的是Timer。因此,改用Timer并在dispose时取消可以避免此问题。示例代码展示了如何在dispose时取消Timer以防止错误发生。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

学习flutter,其中用Futere.delayed延时1s跳转到其他页面的时 如果没跳转前离开当前页面就会报

Future.delayed(const Duration(seconds: 1), () {
  Navigator.of(context).pushNamed("");
});
//报错
This widget has been unmounted, so the State no longer has a context (and should be considered defunct).
    Consider canceling any active work during "dispose" or using the "mounted" getter to determine if the State is still active.

问题分析

说明其实很清楚了,就是widget已经unmounted 不能跳转,我们需要在dispose取消下Future,所以需要看下delayed的源码:

  factory Future.delayed(Duration duration, [FutureOr<T> computation()?]) {
    _Future<T> result = new _Future<T>();
    new Timer(duration, () {
      if (computation == null) {
        result._complete(null as T);
      } else {
        try {
          result._complete(computation());
        } catch (e, s) {
          _completeWithErrorCallback(result, e, s);
        }
      }
    });
    return result;
  }

发现其实内部用是Timer实现,返回的_Future并找到对应方法取消,干脆直接用Timer实现好了,注意还是需要dispose取消

    _timer = Timer(const Duration(seconds: 1), () {
      Navigator.of(context).pushNamed("");
    });
    
	  @override
	  void dispose() {
	    super.dispose();
	    _timer?.cancel();
	  }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值