【问题标题】:Flutter Web shows blank page on GitHub deploymentFlutter Web 在 GitHub 部署上显示空白页面
【发布时间】:2022-10-23 12:35:57
【问题描述】:

问题:

我在 Flutter 中创建了一个 Web 应用程序,并使用 GitHub Pages 部署到了 Web 上。它在第一个版本中运行(页面正常运行,所有内容都正常运行),然后我进行了一些更新并尝试重新部署,网页现在显示为空白。屏幕是白色的。不显示任何内容,仅显示通用标题和网站图标。

当我使用 Chrome 直接从 Android Studio 运行时,我能够正常查看页面。只有当我部署到 GitHub Pages 时,屏幕才显示为空白。

我的过程:

  • 使用flutter build web命令发布,也尝试flutter build web --release等组合
  • 通过上传 build > web 文件夹的内容将代码从 Android Studio 移动到 GitHub Pages

我试过的:

修改删除在类似问题中建议的行的每个组合。

  • 删除<base href=...>
  • <base href="/">
  • <base href="./">
  • <base href="/homepage/">
  • 删除和替换整个 GitHub 存储库
  • 使用flutter build web --web-renderer html 构建
  • 从应用程序本身中删除所有复杂代码,只留下一个横幅

我已阅读有关此主题的每个 StackOverflow 和 GitHub 页面,但没有任何解决方案有效。寻求任何帮助!

这是我的 GitHub 存储库1

这是我的 index.html 文件

<!DOCTYPE html>
<html>
<head>
  <!--
    If you are serving your web app in a path other than the root, change the
    href value below to reflect the base path you are serving from.
    The path provided below has to start and end with a slash "/" in order for
    it to work correctly.
    For more details:
    * https://developer.mozilla.org/en-US/docs/Web/HTML/Element/base
    This is a placeholder for base href that will be replaced by the value of
    the `--base-href` argument provided to `flutter build`.
  -->

  <!--<base href="/">-->

  <meta charset="UTF-8">
  <meta content="IE=Edge" http-equiv="X-UA-Compatible">
  <meta name="description" content="A new Flutter project.">

  <!-- iOS meta tags & icons -->
  <meta name="apple-mobile-web-app-capable" content="yes">
  <meta name="apple-mobile-web-app-status-bar-style" content="black">
  <meta name="apple-mobile-web-app-title" content="sports_app">
  <link rel="apple-touch-icon" href="icons/Icon-192.png">

  <!-- Favicon -->
  <link rel="icon" type="image/png" href="favicon.png"/>

  <title>sports_app</title>
  <link rel="manifest" href="manifest.json">

  <script>
    // The value below is injected by flutter build, do not touch.
    var serviceWorkerVersion = '1014210939';
  </script>
  <!-- This script adds the flutter initialization JS code -->
  <script src="flutter.js" defer></script>
</head>
<body>
  <script>
    window.addEventListener('load', function(ev) {
      // Download main.dart.js
      _flutter.loader.loadEntrypoint({
        serviceWorker: {
          serviceWorkerVersion: serviceWorkerVersion,
        }
      }).then(function(engineInitializer) {
        return engineInitializer.initializeEngine();
      }).then(function(appRunner) {
        return appRunner.runApp();
      });
    });
  </script>
</body>
</html>

【问题讨论】:

    标签: flutter build github-pages flutter-web


    【解决方案1】:

    您可以保留 index.html 上的默认值

     <base href="$FLUTTER_BASE_HREF">
    

    而且你需要改变base-href,像这样构建

    flutter build web --release --web-renderer html --base-href /your_repository_name/
    

    对于 GitPage,它必须是这种格式

    【讨论】:

    • 我将 index.html 更改为 &lt;base href="$FLUTTER_BASE_HREF"&gt; 并使用上面的 build web 行重新构建它。我仍然只看到一个空白页。网址是:jumpinsports.github.io/homepage
    • 您的项目名称和存储库名称是什么,与存储库名称相同?你能包括你的构建命令吗?
    • 项目名称是sports_app。存储库称为主页。我使用的构建命令是:flutter build web --release --web-renderer html --base-href /homepage/ 感谢您对此的帮助
    • 调试模式可以吗?也可以试试sports_app,我更喜欢同名。
    • 我创建了一个名为“sports_app”的存储库并再次尝试使用那个(jumpinsports.github.io/sports_app),但没有修复它。我可以通过 Android Studio 在调试和发布模式下运行它,但在 GitHub Pages 上仍然出现空白屏幕。
    【解决方案2】:

    方法一

    请将 index.html 文件中的 href 更改为以下行,然后重新构建。

    <base href="./">
    

    方法二

    index.html 中的标签。将其更改为 github 存储库的基本路径。在这种情况下,这将是

    <base href="https://jumpinsports.github.io/sports_app/"/>
    

    【讨论】:

    • 我刚刚又试了一次。我将 web>index.html 行修改为&lt;base href="./"。这在过去对我有用。但我现在仍然得到一个空白页。
    • 请尝试方法 2 并再次托管
    • 我也尝试了方法2,但没有运气。我仍然得到一个空白页。
    猜你喜欢
    • 2023-01-01
    • 1970-01-01
    • 2020-11-30
    • 2021-02-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-10-27
    • 1970-01-01
    相关资源
    最近更新 更多