android - Flutter Webview 更改网页不可用

标签 android webview dart flutter android-webview

如果用户没有互联网,我想在我的 WebView 应用程序中更改“网页不可用”。

我阅读了文档,并尝试了一些其他的 puglins

import 'package:webview_flutter/webview_flutter.dart';
[...]
class _MyHomePageState extends State<MyHomePage> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: const WebView(
        initialUrl: 'https://google.com',
        javascriptMode: JavascriptMode.unrestricted,
      ),
    );
  }
}

最佳答案

你可以试试我的插件flutter_inappwebview .当 WebView 正在加载一个 url(onLoadError 事件)以及当它接收到 HTTP 错误(例如 403、404 等)(onLoadHttpError 事件)时,它具有管理错误的事件。

如果用户没有互联网连接,加载自定义错误页面的工作代码的完整示例:

import 'dart:async';

import 'package:flutter/material.dart';

import 'package:flutter_inappwebview/flutter_inappwebview.dart';

Future main() async {
  runApp(new MyApp());
}

class MyApp extends StatefulWidget {
  @override
  _MyAppState createState() => new _MyAppState();
}

class _MyAppState extends State<MyApp> {

  @override
  void initState() {
    super.initState();
  }

  @override
  void dispose() {
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return MaterialApp(
        home: InAppWebViewPage()
    );
  }
}

class InAppWebViewPage extends StatefulWidget {
  @override
  _InAppWebViewPageState createState() => new _InAppWebViewPageState();
}

class _InAppWebViewPageState extends State<InAppWebViewPage> {
  InAppWebViewController webView;

  @override
  Widget build(BuildContext context) {
    return Scaffold(
        appBar: AppBar(
            title: Text("InAppWebView")
        ),
        body: Container(
            child: Column(children: <Widget>[
              Expanded(
                child: Container(
                  child: InAppWebView(
                    initialUrl: "https://flutter.dev/",
                    initialHeaders: {},
                    initialOptions: InAppWebViewWidgetOptions(
                        inAppWebViewOptions: InAppWebViewOptions(
                          debuggingEnabled: true,
                        ),
                    ),
                    onWebViewCreated: (InAppWebViewController controller) {
                      webView = controller;
                    },
                    onLoadStart: (InAppWebViewController controller, String url) {

                    },
                    onLoadStop: (InAppWebViewController controller, String url) {

                    },
                    onLoadError: (InAppWebViewController controller, String url, int code, String message) async {
                      print("error $url: $code, $message");

                      var tRexHtml = await controller.getTRexRunnerHtml();
                      var tRexCss = await controller.getTRexRunnerCss();

                      controller.loadData(data: """
<html>
  <head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0,maximum-scale=1.0, user-scalable=no">
    <style>$tRexCss</style>
  </head>
  <body>
    $tRexHtml
    <p>
      URL $url failed to load.
    </p>
    <p>
      Error: $code, $message
    </p>
  </body>
</html>
                  """);
                    },
                    onLoadHttpError: (InAppWebViewController controller, String url, int statusCode, String description) async {
                      print("HTTP error $url: $statusCode, $description");
                    },
                  ),
                ),
              ),
            ]))
    );
  }
}

结果是:

此示例直接加载 html 源,但您可以从 assets 文件夹或 url 加载 html 文件。

只是为了好玩:我的插件包含 Google Chrome 霸王龙游戏的 javascript 和 css 代码!

关于android - Flutter Webview 更改网页不可用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55315107/

相关文章:

javascript - 如何将来自webview的数据存储在localdata UWP中

visual-studio-code - VSCode 突出显示 Flutter 错误,但 Android Studio 没有

android - 使用另一个没有 google play 的 apk 更新已安装的 android apk

android - 如何为多平台创建 Storybook 应用程序

java - newSingleThreadScheduledExecutor 的工作,如果线程已经忙

Android 在没有空格的 webview 上添加 HTML 内容

javascript - 更改配置后通过WebView和JS函数调用JavascriptInterface方法经常不起作用

android - 如何在 Android 数据绑定(bind)中的属性更改时得到通知?

dart - Flutter:通过 Google Firebase 授权时出错

flutter - 无法使用 SizedBox 限制 Card 的高度