flutter web 路由问题

开发问题背景:

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

项目中使用的路由是 GetX 4.6.0

存在的问题

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

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

解决方案

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

dart 复制代码
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.

相关推荐
喜欢踢足球的老罗15 分钟前
搭建一个本地轻量级且好用的学习TypeScript语言的环境
javascript·学习·typescript
豆豆(设计前端)18 分钟前
总结 Vue 请求接口的各种类型及传参方式
前端·javascript·vue.js
BestArsenaI18 分钟前
vue -关于浏览器localstorge数据定期清除的实现
javascript·vue.js·ecmascript
Smile_Gently29 分钟前
Element-plus、Element-ui之Tree 树形控件回显Bug问题。
javascript·vue.js·elementui
一生躺平的仔40 分钟前
# Rust遇上WebAssembly:让JavaScript的计算性能起飞!🚀
前端·javascript
IT 古月方源42 分钟前
跨站脚本攻击(XSS)详解
运维·服务器·前端·网络·tcp/ip·网络安全·xss
你的码,就是我的码1 小时前
web服务器架构,websocket
服务器·前端·架构
彭友圈1011 小时前
HTML基础入门——简单网页页面
前端·前端框架·html
丁总学Java2 小时前
/src/utils/request.ts:axios 请求封装,适用于需要统一处理请求和响应的场景
开发语言·javascript·ecmascript
m0_749317522 小时前
VUE学习
前端·javascript·vue.js·学习