flutter路由传参接收时机

dart 复制代码
@override
  void initState() {
    super.initState();
    // 这里没有使用微任务,而是用的0帧
    Future.delayed(Duration.zero, () {
      dynamic obj = 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);
    });
  }
dart 复制代码
// 使用微任务
String _routeGetArguments = "";
  @override
  void initState() {
    super.initState();
    /// 异步微任务接收
    Future.microtask((){
      if(ModalRoute.of(context) != null){
        Map<String,dynamic> params = ModalRoute.of(context)!.settings.arguments as Map<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可用

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

微任务 vs 延迟零秒的区别

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

为什么不是微任务

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

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

相关推荐
SoaringHeart9 分钟前
Flutter进阶:OverlayEntry 插入图层管理器 NOverlayZIndexManager
前端·flutter
一只大袋鼠21 分钟前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
LuminousCPP1 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习
web3.08889991 小时前
1688 图搜接口(item_search_img / 拍立淘) 接入方法
开发语言·python
один but you2 小时前
从可变参数到 emplace:现代 C++ 性能优化的核心组合
java·开发语言
MY_TEUCK3 小时前
【Java 后端 | Nacos 注册中心】微服务治理原理、选型与注册发现实战
java·开发语言·微服务
测试员周周3 小时前
【Appium 系列】第13节-混合测试执行器 — API + UI 的协同执行
开发语言·人工智能·python·功能测试·ui·appium·pytest
光泽雨4 小时前
c#中的Type类型
开发语言·前端
见叶之秋4 小时前
C++基础入门指南
开发语言·c++
计算机安禾4 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法