- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这似乎是一个简单但又令人困惑的问题。我已经使用 Ionic 1 很长时间了,两年前才接触到 Ionic 2+,但已经有一段时间没有使用它了。
最近,我注意到 Ionic 发布了 Ionic PWA但我不明白他们是否属于同一个项目或完全分开。我知道 Ionic PWA 是一个网络应用程序框架,而传统的 Ionic 仅用于/推荐用于混合应用程序。
所以我的问题是:
它们是合并在一起还是分开?
如果它们是分开的,是否可以轻松地从 Ionic3 迁移到 Ionic PWA? (我可能需要更多浏览器支持)
谢谢!
更新这个问题是基于错误的假设提出的,即 Ionic PWA 是一个独立但与原始 Ionic 相似的框架。显然,Ionic PWA 只是原始 Ionic 的一个术语,经过一些小改动(您必须自己做)以使其成为 PWA。
最佳答案
PWA 与混合应用的不同之处在于,它们在网络浏览器的上下文中运行,而不是在操作系统级别的 WebView 中运行(更多关于 Android 和 iOS 的 WebView)。 PWA 就像一个网页,有自己的应用程序图标,并在没有标签和 URL 栏等的全屏 Web 浏览器中运行。
因此,PWA 无法像混合应用那样访问原生功能。例如,如果您想在混合应用程序中访问手机的相机,您可以使用 Cordova 插件之类的东西(在您的 Ionic 应用程序中,您将使用 @ionic-native/camera )。要从 PWA(本质上是从网络浏览器)访问相机,Cordova 将无法工作——您需要使用网络 API ( see what web APIs can do! )。
由于 PWA 的架构需要与常规混合应用程序的架构完全不同(应用程序越复杂,差异越大),Ionic 已从 Ionic PWA 分支出来,以帮助开发人员更轻松地创建 PWA。
要使您的 Ionic3 应用程序作为 PWA 运行:如果您使用 ionic start
从 Ionic 入门应用程序模板之一创建了 Ionic 应用程序,您可以做两件事来让您的应用程序作为 PWA 运行。
添加 manifest.json
文件到您的/src
文件夹并在您的 index.html
中添加指向它的链接: <link rel="manifest" href="/manifest.json">
. An example的 manifest.json
和 further reading .
通过在您的 index.html
中找到以下代码片段来启用 Service Worker 支持并取消注释。不过,我发现需要做更多的工作才能真正让 Service Worker 工作。更多信息 MDN .
<!-- un-comment this code to enable service worker
<script>
if ('serviceWorker' in navigator) {
navigator.serviceWorker.register('service-worker.js')
.then(() => console.log('service worker installed'))
.catch(err => console.error('Error', err));
}
</script>-->
然后运行ionic build
并部署 www
文件夹到网络,最好通过 HTTPS 提供。如果您从移动浏览器打开该页面,您应该能够在 Android 和 iOS(iOS > 版本 11.3)上“添加到主屏幕”并将该应用程序作为 PWA 运行。
请记住,您拥有的任何 Cordova 功能都将不起作用。此外,如果您使用 lazy-loading ,这将有助于提升应用性能。
关于angular - Ionic PWA 与传统 Ionic 是分开的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50775419/
我是 Redis 的新手,我现在正在尝试制作一个登录功能来学习它。 假设我在传统 SQL 数据库中有一个名为 User (id, username, password) 的表,设计 Redis 的正确
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题?通过 editing this post 添加详细信息并澄清问题. 5年前关闭。 Improve this
我刚刚遇到了具有所有天赐优势的 NoSQL 系统。其中之一似乎是毫不费力的水平缩放。我的问题是,为什么像 MySQL 或 SQL Server 这样的经典 RDBMS 不能进行水平扩展?或者无法做到与
问题 Although you can explicitly check if a value is true or false, it's a convention in JavaScript to
用于突发错误纠正的 ECC 如何工作? “突发错误检测”是指一种技术,可以检测(例如)任何一个 [或两个] 64 位连续位序列中的任何位错误组合。 我需要概念上的解释,而不是数学。 我研究了几种用无穷
我试图向学生说明传统 IO 和 java 中的内存映射文件之间的性能差异。我在互联网上的某个地方找到了一个例子,但我并不是很清楚所有的事情,我什至不认为所有的步骤都是必要的。我在这里和那里阅读了很多关
如何在 PhpStorm 中自动将短数组语法转换为长数组(传统)? 我使用了PhpStorm中的“代码->检查代码”功能,然后一键将短语法转换为长语法。 检查代码 手动转换 必须有一种方法来自动化这项
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我发现 Light Table 是尝试 Clojure 语言的好工具。 它有一个方便的功能叫做 Instarepl - ;;您在此处输入的任何内容都将立即执行,结果显示在右侧。 但是,我找不到使用旧式
我们有一个经典的 ASP 应用程序,所有数据都是使用表格呈现的(是的,我们正在努力将其转换为 DIV,但我们离那还有一段距离)。我们设置了一个标准的表格宽度,通常这可以正常工作,但有些元素的大小可以由
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 7 年前。 Improve
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 6年前关闭。 Improve this
这只是一个一般性问题。传统的 ajax 和 jquery ajax 哪个更好?因为当我使用 jquery ajax 时,它似乎在 IE 中做了一些奇怪的事情。它应该是一个跨浏览器库......所以我对
所有这些都是为了丢弃MVC Controller 的问题。 这是ajax的代码: $.ajax({ //tipo de transferencia t
我知道它可能应该是另一种方式(OSGI 运行时托管 Java EE 服务器),因为它是 apparently already possible with glassfish. 但是,我们的客户在管理传
作为具有一些 winforms 和客户端应用程序经验的人 - 是否值得回去学习传统的 ASP .NET 页面的工作方式,或者直接进入 ASP .NET MVC 是否可以? 我正在寻找我对 C# 的一般
如果我错了,请纠正我:在传统的Web应用程序中,浏览器会自动将 session 信息附加到对服务器的请求中,以便服务器可以知道该请求来自谁。实际上到底附加了什么? 但是,在基于 API 的应用程序中,
我正在使用Eclipse neon 3,当我导入一个使用WebSphere Application Server传统V9.0作为运行时环境的项目时,它显示了一个错误,宣布 Target runtime
背景: 我的 REST 服务项目是使用 Hibernate 启动的。我在域类中使用 id (Long) 作为 rest url 中标识符的一部分,例如: http://abc.com/customer
在 Scheme 中递归构建列表时,我看到两种类型的示例散布在互联网上。其中一个新值附加了 append每一次迭代。另一个在每次迭代前都添加一个新值 cons然后列表完成后reverse被调用一次。
我是一名优秀的程序员,十分优秀!