Flutter中的widget生命周期监听

在flutter项目中需要对widget的生命周期进行监听,但是sdk中的监听方法不太好用,所以抽取了一个State的基类,用来监听widget的生命周期。
包括Flutter的生命周期监听和widget的生命周期监听,由于代码比较简单,大家有需要的直接领走,具体使用方式见注释。

import 'package:flutter/material.dart';

/// 创建日期: 2020/8/14
/// 作者: lijianbin
/// 描述:

///路由监听,使用时在MaterialAPP中的navigatorObservers直接赋值
///
/// void main() {
///  runApp(MaterialApp(
///    navigatorObservers: [lifeObserver],
///    home: FirstWidget(),
///  ));
///}

final RouteObserver<Route> lifeObserver = RouteObserver();

///具有Widget生命周期监听的State类,使用时和State方式一样,
///当widget可见时,回调onResume(),
///不可见时,回调onPaused(),
///
///当Apush打开B,A会调用onPaused(),B调用onResume();
///当Bpop返回A,A会调用onResume(),B调用onPaused();
///当锁屏或退入后台时,会调用onPaused();
///当从后台转入前台或从锁屏解锁后,会调用onResume();
///
/// 使用时,直接将State替换为LifeState即可
/// 不建议在回调用做大量的耗时操作,可以做一些定时任务的启停标记
///
abstract class LifeState<T extends StatefulWidget> extends State<T>
    with WidgetsBindingObserver, RouteAware {
  @override
  void initState() {
    WidgetsBinding.instance.addObserver(this);
    super.initState();
  }

  @override
  void didChangeDependencies() {
    lifeObserver.subscribe(this, ModalRoute.of(context));
    super.didChangeDependencies();
  }

  @override
  void dispose() {
    WidgetsBinding.instance.removeObserver(this);
    lifeObserver.unsubscribe(this);
    super.dispose();
  }

  @override
  void didChangeAppLifecycleState(AppLifecycleState state) {
    if (state == AppLifecycleState.resumed) {
      onResume();
    } else if (state == AppLifecycleState.paused) {
      onPaused();
    }
  }

  void didPop() {
    onPaused();
  }

  void didPopNext() {
    onResume();
  }

  void didPush() {
    onResume();
  }

  void didPushNext() {
    onPaused();
  }

  void onResume();

  void onPaused();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值