我们有用 Svelte/Sapper 编写的 PWA 应用程序,我们希望在移动平台上转换这个应用程序。由于某些业务原因,我们需要在 Android 和 iOS 商店中明确应用。
- 在 Android 情况下很容易。我们将使用 Google TWA,一切都会很好。
- 在 Apple iOS 上,我觉得这很困难。没有适用于 iOS 的 Google TWA 之类的东西。而且苹果商店的大量要求也会很痛苦。
小提示:我们不需要移动平台上的任何原生 API。纯 JavaScript 浏览器 API 对我们来说已经足够了。
所以我找到了我认为最适合我们的问题的 Apache Cordova 项目,并且我找到了 Svelte 的模板syonip/svelte-cordova-template
。但这还不够。模板正在解决 Svelte 但不是 Sapper。
最好的情况是我下载了一些 Cordova/Svelte/Sapper 模板,复制现有的源代码,在途中修复一些问题,将应用程序导出到 xCode 项目,构建它,它将在 iOS 上运行而没有任何重大问题(当然我预计会进行一些代码更改,但不会完全重写应用程序)。
您是否对 Svelte/Sapper -> Cordova 迁移有一些经验?
Edit1:我认为可以使用 Sapperexport
功能并将构建的文件传递给 Cordova。当用户手动更改 URL 地址时,它会出现一些问题,例如无法正常运行路由(但对于这个特定的用例 - 移动应用程序 - 这不是问题,因为用户将无法编辑 URL)。服务器端渲染、预加载和预取也是不可能的。
Edit2:经过一番挖掘,我认为不可能将 Sapper 应用程序转换为 Cordova。Sapper 中的代码拆分存在很多问题。最大的问题发生在 CORS 策略上,事实上 Sapper 应用程序旨在与服务器和域一起使用,而不是来自文件系统。也许可以在 Cordova 中使用一些隐藏的本地主机服务器来提供文件,但这会带来问题并且非常讨厌。
Edit3:我们将现有的 Svelte/Sapper 代码库与 Flutter 和 Google TWA 一起使用。Flutter 应用程序包含引用前端应用程序的公共 URL 地址的 webview。