Flutter InAppWebView 路由导航处理

flutter InAppWebView路由导航处理,有以下两种处理方案:

  1. H5层控制路由,H5拥有自己的路由,当返回到跟路由root时,此时点击跟节点,通过jsbridge调用flutter提供的方法来关闭当前widget,flutter关闭方法如下:

    Dart 复制代码
    value.addJavaScriptHandler(
        handlerName: "closeInAppWebView",
        callback: (args) {
          //关闭当前widget  
          Navigator.pop(context);
        });
  2. flutter层控制路由,通过InAppWebViewController中canGoBack()判断是否可以返回,可以返回调用goBack(),否则关闭当前widget。代码如下:

    Dart 复制代码
    if (await inAppWebViewController!.canGoBack()) {
        //返回路由上一层
        inAppWebViewController!.goBack();
    } else {
        //关闭当前widget
        Navigator.pop(context);
    }
相关推荐
旧时光_8 小时前
第4章:布局类组件 —— 4.8 LayoutBuilder、AfterLayout
flutter
A懿轩A8 小时前
Flutter:跨平台开发终极指南
flutter
肠胃炎13 小时前
Flutter 基础组件
前端·flutter
木易士心13 小时前
Flutter 网络请求深度解析
flutter
消失的旧时光-194314 小时前
Flutter Scaffold 全面解析:打造页面骨架的最佳实践(附场景示例 + 踩坑分享)
前端·flutter
Q6882388616 小时前
三菱Q系列PLC大型自动化生产线程序案例分享
flutter
消失的旧时光-194316 小时前
Flutter 布局入门
flutter
天天开发1 天前
Flutter每日库: image_picker选取相册图片视频
flutter
消失的旧时光-19432 天前
Flutter 组件:StatelessWidget vs StatefulWidget
flutter