news 2026/4/15 12:09:07

flutter路由传参接收时机

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
flutter路由传参接收时机
@overridevoidinitState(){super.initState();// 这里没有使用微任务,而是用的0帧Future.delayed(Duration.zero,(){dynamicobj=ModalRoute.of(context)?.settings.arguments;if(obj!=null){classId=obj["classId"];title=obj["title"];needPop=true;}else{classId=widget.classId;title=widget.title;}loadData(update:true);});}
// 使用微任务String_routeGetArguments="";@overridevoidinitState(){super.initState();/// 异步微任务接收Future.microtask((){if(ModalRoute.of(context)!=null){Map<String,dynamic>params=ModalRoute.of(context)!.settings.argumentsasMap<String,dynamic>;_routeGetArguments=params["index"].toString();///更新视图,要不然UI中不会显示出来,记住一定要写setState((){});}else{print("获取不到路由参数");}});}

在Flutter中,这里使用Future.delayed(Duration.zero)而不是微任务,主要是出于构建上下文生命周期的考虑。

为什么使用Future.delayed(Duration.zero)

  1. 避免在build期间访问路由参数

    • initState()中,widget尚未完成首次构建
    • 直接访问ModalRoute.of(context)可能会因为context还未完全建立而返回null
    • Future.delayed(Duration.zero)将执行推迟到当前帧构建完成后
  2. 确保context可用

    // 这样可能无法正确获取路由参数dynamicobj=ModalRoute.of(context)?.settings.arguments;// 可能为null// 使用延迟确保context已准备好Future.delayed(Duration.zero,(){dynamicobj=ModalRoute.of(context)?.settings.arguments;// 更安全});

微任务 vs 延迟零秒的区别

  • 微任务(scheduleMicrotask):在当前事件循环的微任务队列中执行,比UI渲染优先级更高
  • Future.delayed(Duration.zero):在下一个事件循环中执行,确保当前widget构建过程已完成

为什么不是微任务

在这个场景下,使用微任务可能过早执行,因为widget可能还在构建过程中。而Future.delayed(Duration.zero)确保在widget完全构建后再执行参数获取,这样ModalRoute.of(context)能够正确获取到路由参数。

这种方式是Flutter中处理"需要等待widget构建完成后再执行"的常见模式。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/13 3:05:33

为什么顶尖开发者都在私藏这款AI工具?智谱Open-AutoGLM PC深度揭秘

第一章&#xff1a;智谱 Open-AutoGLM PC 的崛起背景随着人工智能技术的飞速发展&#xff0c;自动化机器学习&#xff08;AutoML&#xff09;逐渐成为推动AI普惠化的重要方向。在这一背景下&#xff0c;智谱AI推出了 Open-AutoGLM PC&#xff0c;旨在将大语言模型与自动化建模能…

作者头像 李华
网站建设 2026/4/13 15:14:12

如何用Open-AutoGLM实现全自动Prompt工程?一文讲透

第一章&#xff1a;Open-AutoGLM与全自动Prompt工程概述Open-AutoGLM 是一个面向大语言模型&#xff08;LLM&#xff09;的开源自动化 Prompt 生成框架&#xff0c;旨在通过算法驱动的方式优化提示词设计流程。传统 Prompt 工程依赖人工经验反复调试&#xff0c;而 Open-AutoGL…

作者头像 李华
网站建设 2026/4/15 8:40:23

springboot基于vue的摄影跟拍预约系统_0370ky6v

目录已开发项目效果实现截图开发技术介绍核心代码参考示例1.建立用户稀疏矩阵&#xff0c;用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度系统测试总结源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;已开发项目效果…

作者头像 李华
网站建设 2026/4/15 10:25:42

PaddlePaddle图神经网络GNN入门:Node Classification任务

PaddlePaddle图神经网络GNN入门&#xff1a;Node Classification任务 在社交网络中&#xff0c;如何自动识别用户的职业或兴趣&#xff1f;在学术文献库中&#xff0c;能否根据论文间的引用关系预测其研究领域&#xff1f;这类问题本质上都归结为图上的节点分类任务——而图神…

作者头像 李华
网站建设 2026/4/15 10:25:42

PaddlePaddle工业缺陷检测系统部署全流程

PaddlePaddle工业缺陷检测系统部署全流程 在现代智能制造产线上&#xff0c;一台PCB板从贴片到焊接完成只需几秒钟&#xff0c;而传统质检员却需要数秒甚至更长时间才能完成一次肉眼检查。面对每分钟数十件产品的高速节拍&#xff0c;人工不仅难以跟上节奏&#xff0c;还极易因…

作者头像 李华
网站建设 2026/4/9 16:48:54

PaddlePaddle自动驾驶感知系统构建指南

PaddlePaddle自动驾驶感知系统构建指南 在自动驾驶的研发浪潮中&#xff0c;环境感知始终是决定系统“看得清、判得准”的核心环节。面对城市复杂路况下对车辆、行人、交通标志等目标的高精度实时识别需求&#xff0c;传统视觉算法已难以满足性能与鲁棒性的双重挑战。而深度学习…

作者头像 李华