【发布时间】: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