跳到主要内容
版本:v5

构建渐进式 Web 应用

Capacitor 对渐进式 Web 应用(PWA)拥有一流支持,使构建一个在 iOS 和 Android 上原生运行,同时在 Web 上作为移动 Web 应用或"渐进式 Web 应用"运行的应用变得容易。

什么是渐进式 Web 应用?

简而言之,渐进式 Web 应用(PWA)是一种使用现代 Web 能力为用户提供类似应用体验的 Web 应用。这些应用部署到传统的 Web 服务器,通过 URL 访问,并且可以被搜索引擎索引。

渐进式 Web 应用实际上只是针对移动性能进行了优化,并利用新可用的 Web API 来提供类似传统原生应用的功能(如推送通知和离线存储)的网站的另一种说法。

Capacitor 和渐进式 Web 应用

Capacitor 对渐进式 Web 应用原生应用都有一流支持。这意味着 Capacitor 的桥接支持在原生环境或 Web 环境中运行,许多插件在两种环境中都以完全相同的 API 和调用约定可用。

这意味着您使用 @capacitor/core 和 Capacitor 插件作为原生应用渐进式 Web 应用的依赖项,Capacitor 会在需要时无缝地调用 Web 代码,在可用时调用原生代码。

此外,Capacitor 提供了许多用于查询当前平台的实用工具,以便在原生运行或在 Web 上运行时提供定制化的体验。

为您的应用添加渐进式 Web 应用支持

渐进式 Web 应用应该有一个应用 Manifest 和一个 Service Worker。

应用 Manifest

首先,您需要一个应用 Manifest 文件(manifest.json),它与您的 index.html 文件放在一起,并提供有关应用的元数据,例如名称、主题颜色和图标。例如,当您的应用被安装到主屏幕时,将使用这些信息。

Service Worker

接下来,为了发送推送通知和离线存储数据,Service Worker 将使您的 Web 应用能够代理网络请求并执行处理和同步数据所需的后台任务。

Service Worker 功能强大但复杂。通常,不建议从头开始编写它们。相反,请查看像 Workbox 这样的工具,它们提供了常见的 Service Worker 方案,您可以轻松地将其整合到应用中。

在 MDN 的使用 Service Workers 页面上阅读更多关于使用 Service Worker 的信息,包括如何注册它们。

渐进式 Web 应用性能

渐进式 Web 应用通过多个性能标准来评判,包括可交互时间首次有效绘制

在发布之前,请遵循渐进式 Web 应用检查清单,并使用 Lighthouse 来审计和测试您的应用。

如果您在使用现有前端技术栈时难以达到渐进式 Web 应用性能标准,请将 Ionic Framework 作为几乎零配置即可快速获得 PWA 支持的一个选项。