IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> 【Flutter】关于对话框showDialog传入context无效问题 -> 正文阅读

[移动开发]【Flutter】关于对话框showDialog传入context无效问题

  1. 当执行异步操作,或者从下一个页面返回结果时,需要调用类似如下加载对话框代码,有时就会出现不能展示的问题,调式发现传入的context是无效的
	/**
	* showLoading()
	* 加载对话框
	*/
  Future<T?> showLoadingAlert<T>(BuildContext context, Function task) async {
    return await showDialog<T>(context: context, builder: (context) {
      (() async {
        Navigator.of(context).pop(await task(context));
      })();
      return UnconstrainedBox(
        child: SizedBox(
          width: 200,
          child: AlertDialog(
            content: Column(
              mainAxisSize: MainAxisSize.min,
              children: const [
                CircularProgressIndicator(),
                Padding(
                  padding: EdgeInsets.only(top: 20),
                  child: Text("加载中..."),
                ),
              ],
            ),
          ),
        ),
      );
    }, barrierDismissible: false);
  }
  1. 如果想通过这样添加判断mounted解决,就会觉得实在不妥,因为这样不能保证顺利执行下去
 if (!mounted) {
   print('$c not mounted!');
   //...
 } else {
 	var result = await showLoadingAlert(context, () async {
		//handler task
	});
   //...;
 }
  1. 查过网上的资料,最后整理出来,改成如下这样试试,注意到MyPage页面代码中有定义了stateKey,最后赋值给key了,
class MyPage extends StatelessWidget with MixWidget {
	final stateKey = GlobalKey<ScaffoldState>();

	@override
	Widget build(BuildContext context) {
		return Scaffold(
      		key: stateKey,
      		//...
      	}
	}
	
	//...
  Future<T?> showLoadingAlert<T>(Function(BuildContext context) task) async {
    return await showDialog<T>(context: stateKey.currentContext!, builder: (context) {
      (() async {
        Navigator.of(context).pop(await task(context));
      })();
      return UnconstrainedBox(
        child: SizedBox(
          width: 200,
          child: AlertDialog(
            content: Column(
              mainAxisSize: MainAxisSize.min,
              children: const [
                CircularProgressIndicator(),
                Padding(
                  padding: EdgeInsets.only(top: 20),
                  child: Text("加载中..."),
                ),
              ],
            ),
          ),
        ),
      );
    }, barrierDismissible: false);
  }
  //...
}
  1. 运行以后,代码如下,只要调用showLoadingAlert()方法,不再传入context,就能展示加载对话框了
onClick() async {
 	var result = await showLoadingAlert(() async {
		//执行耗时请求
		//...
	});
   //...;
}
  1. 最后,附上运行结果截图
    在这里插入图片描述
  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-03-15 22:41:49  更:2022-03-15 22:42:25 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 17:44:15-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码