2

我们有用 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。

4

1 回答 1

1

您需要科尔多瓦应用程序中的节点来运行节点(工兵)应用程序。

所以,

  1. 在科尔多瓦应用程序中包含节点: https ://www.npmjs.com/package/nodejs-mobile-cordova

  2. 通过运行 nodejs.start 在您的应用程序启动节点中

  3. 使用运行 npm start 的脚本启动您的 sapper 应用程序

  4. 打开你的 webview 到工兵索引路由。

顺便说一句,我还没有尝试过,这只是一种预感:)

于 2019-12-28T23:40:55.167 回答