当前位置: 首页 > article >正文

flutter web 路由问题

开发问题背景:

flutte 项目中开发网页暴露出来供外部的 网页调用,并不是跳转到项目的首页

项目中使用的路由是 GetX 4.6.0

存在的问题

  • 跳回到首页的问题
  1. web -> flutter
  2. flutter 使用 history.back 到web,
  3. web forward 到 flutter

此时不会返回到上一个flutter页面,而是跳转到了首页。因为flutter应用已经关闭了,再次进来就会重启应用了,所以就会是首页。

解决方案

记录上次非空Path的链接到 localStorage 中,下次进来如果是首页或者path为 / , 则进入上次的链接

String path = AppRoutes.HOME;
    if (GetPlatform.isWeb) {
      final uri = Uri.parse(web.window.location.href);
      path = '${uri.path}?${uri.query}';
      if (uri.path.isNotEmpty && uri.path != "\/") {
        web.window.localStorage.setItem('init_route', path);
      } else {
        path = web.window.localStorage.getItem('init_route')??"";
      }
    }
    
    GetMaterialApp(
            ...
            initialRoute: path
            ...
            )
使用 get: ^5.0.0-release-candidate-9.2.1 进行解决,

这样就不会出现back forward 返回到首页的问题,但是又回出现新的问题,

其他页面使用使用Get.back返回, 根页面使用 history.back 返回会返回到之前关闭的flutter web页面

解决方案:其他页面在使用Get.back 返回之前调用一下 history.back.


http://www.kler.cn/a/471864.html

相关文章:

  • 【Qt】C++11 Lambda表达式
  • C语言文件学习
  • 数据库回滚:大祸临头时
  • 复合机器人助力手机壳cnc加工向自动化升级
  • JAVA学习记录1
  • 【Linux】Linux的权限问题
  • 李正国教授、张钊博士到访美尔斯通,共绘心磁图技术新蓝图
  • jenkins入门10--自动化构建
  • 嵌入式驱动开发详解11(INPUT子系统)
  • 基于Spring Boot的社区老人健康信息管理系统的设计与实现(LW+源码+讲解)
  • 加速科技荣获“浙江省企业研究院”认定
  • with as提高sql的执行效率
  • 细说STM32F407单片机以轮询方式读写外部SRAM的方法
  • vue.js 插槽-作用域插槽
  • TDesign组件-1
  • Bash语言的编程范式
  • api接口对体育直播的重要性
  • spark——DAG专题
  • 万界星空科技电机行业MES系统解决方案
  • C++头文件map