在应用中升级 Capacitor 至 3.0 版本
Capacitor 3 为生态系统带来了重要更新和令人兴奋的新功能。
将应用升级到 Capacitor 3 后,欢迎您在此讨论区分享任何反馈意见。我们期待听到您的声音!💖
如果您是插件开发者,希望将插件升级到更新的 Capacitor 版本,请参阅Capacitor 插件升级指南。
NodeJS 12+
Node 8 已停止支持。Node 10 将于 2021 年 4 月 30 日停止支持。Capacitor 3 需要 NodeJS 12 或更高版本。(推荐使用最新的 LTS 版本。)
Ionic CLI
如果您正在使用 Ionic CLI,官方对 Capacitor 3 的支持从版本 6.16.0 开始。我们建议此时通过 npm install -g @ionic/cli 升级到最新版本。
更新 Capacitor CLI 和 Core
npm install @capacitor/cli@latest-3 @capacitor/core@latest-3
ES2017+
Capacitor 3 现在针对 ES2017 环境构建,而非 ES5。插件模板也已更新为面向 ES2017,鼓励第三方插件更新其目标 环境。
除非您需要支持 IE11(Capacitor 官方不支持),否则此更改不应影响您的应用。
TypeScript 3.8+
Capacitor 3 使用了仅在 TS 3.8 或更高版本中可用的较新 TypeScript 语法。
Capacitor 配置变更
如果您已安装 TypeScript 3.8+,可以将 capacitor.config.json 迁移为名为 capacitor.config.ts 的强类型 TypeScript 配置文件。您可以继续使用 .json 文件,但 TypeScript 配置文件可能为您的团队提供更好的开发体验。以下是一个在 Capacitor 测试应用中使用的 capacitor.config.ts 文件示例。
/// <reference types="@capacitor/local-notifications" />
/// <reference types="@capacitor/push-notifications" />
/// <reference types="@capacitor/splash-screen" />
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
appId: 'com.capacitorjs.app.testapp',
appName: 'capacitor-testapp',
webDir: 'build',
plugins: {
SplashScreen: {
launchAutoHide: false,
},
LocalNotifications: {
smallIcon: 'ic_stat_icon_config_sample',
iconColor: '#CE0B7C',
},
PushNotifications: {
presentationOptions: ['alert', 'sound'],
},
},
};
export default config;
官方插件
所有插件都已从 Capacitor 核心库中移除,并置于各自的 npm 包中。这有几个原因(参见 #3227),核心团队确信这是正确的方向。您可以像这样导入核心插件。
import { Camera } from '@capacitor/camera';
后台任务、权限和照片插件已被移除
- 后台任务:此插件似乎很少使用,且工作方式与大多数开发者的预期不符。核心团队将在未来重新设计后台功能。关注 #3032 获取更新。
- 权限:核心团队已实现了一种替代这种集中式方法的新方案,社区插件也可能采用(参见新的权限 API)。
- 照片:这个未记录的仅限 iOS 的插件已被移除。请使用
@capacitor-community/media。
可访问性、应用和模态框插件被拆分
- 可访问性
- VoiceOver 和 TalkBack 功能移至 屏幕阅读器
- 应用
- 模态框
将您的应用迁移到使用新的官方插件包
此变更需要您单独安装每个正在使用的插件。
- 在您的项目中搜索从
@capacitor/core的Plugins对象中提取的核心插件 - 查找对应的插件文档,请记住有些插件已被拆分
- 按照文档中每个插件的安装说明进行操作
- 将插件导入改为从插件包导入(参见插件导入)
- 遵循向后不兼容的插件变更中的任何说明
使用 Ionic Framework 吗?
Ionic Framework 使用了以下插件中的 API:
为了获得 Ionic Framework 的最佳用户体验,即使您没有在应用中导入这些插件,也应确保它们已安装:
npm install @capacitor/app @capacitor/haptics @capacitor/keyboard @capacitor/status-bar
插件导入
Plugins 对象已被弃用,但在 Capacitor 3 中将继续工作。Capacitor 插件应更新为使用新的插件注册 API(参见插件升级指南),这将允许它们直接从插件包导入。
未来,不应再使用来自 @capacitor/core 的 Plugins 对象。
// 旧方式
import { Plugins } from '@capacitor/core';
const { AnyPlugin } = Plugins;
首选直接从插件包导入插件,但插件必须更新以兼容 Capacitor 3 才能实现此操作。
// 新方式
import { AnyPlugin } from 'any-plugin';