从 Capacitor 3 升级到 Capacitor 4
与之前的升级相比,Capacitor 3 与 4 之间的破坏性变更相对较少。本指南将介绍将项目更新到当前 Capacitor 4 版本的步骤,以及我们官方插件的破坏性变更清单。
使用 CLI 进行迁移
使用 npm i -D @capacitor/cli@latest-4 将最新版本的 Capacitor CLI 安装到你的项目中。安装完成后,只需运行 npx cap migrate 即可让 CLI 为你处理迁移过程。如果任何迁移步骤无法完成,终端输出中会提供额外信息。以下是手动迁移的步骤说明。
iOS
以下指南描述如何将 Capacitor 3 iOS 项目升级到 Capacitor 4。
提高 iOS 部署目标
在你的 Xcode 项目中执行以下操作:在项目编辑器中 选择 Project,然后打开 Build Settings 选项卡。在 Deployment 部分,将 iOS Deployment Target 更改为 iOS 13.0。对任何应用 Targets 重复相同的步骤。
然后,打开 ios/App/Podfile 并按照以下步骤操作:
- 在第一行添加:
require_relative '../../node_modules/@capacitor/ios/scripts/pods_helpers'
- 将 iOS 版本更新为 13.0:
platform :ios, '13.0'
- 在最后一行添加此代码块:
post_install do |installer|
assertDeploymentTarget(installer)
end
移除不必要的代码
从 AppDelegate.swift 中移除未使用的 touchesBegan 方法
-override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) {
- super.touchesBegan(touches, with: event)
-
- let statusBarRect = UIApplication.shared.statusBarFrame
- guard let touchPoint = event?.allTouches?.first?.location(in: self.window) else { return }
-
- if statusBarRect.contains(touchPoint) {
- NotificationCenter.default.post(name: .capacitorStatusBarTapped, object: nil)
- }
-}
可选:从 Info.plist 中移除 NSAppTransportSecurity 条目
NSAppTransportSecurity 仅用于实时重载,如果你不使用实时重载或使用 Ionic CLI 进行实时重载,则不再需要此条目。
-<key>NSAppTransportSecurity</key>
-<dict>
- <key>NSAllowsArbitraryLoads</key>
- <true/>
-</dict>
Android
以下指南描述如何将 Capacitor 3 Android 项目升级到 Capacitor 4。
更新 Android 项目变量
在你的 variables.gradle 文件中,将值更新为以下新的最低要求,并添加新的 coreSplashScreenVersion 和 androidxWebkitVersion
minSdkVersion = 22
compileSdkVersion = 32
targetSdkVersion = 32
androidxActivityVersion = '1.4.0'
androidxAppCompatVersion = '1.4.2'
androidxCoordinatorLayoutVersion = '1.2.0'
androidxCoreVersion = '1.8.0'
androidxFragmentVersion = '1.4.1'
coreSplashScreenVersion = '1.0.0-rc01'
androidxWebkitVersion = '1.4.0'
junitVersion = '4.13.2'
androidxJunitVersion = '1.1.3'
androidxEspressoCoreVersion = '3.4.0'
cordovaAndroidVersion = '10.1.1'
向 Android 清单添加 android:exported 标签
在你的 AndroidManifest.xml 文件中,需要向 <activity> 标签添加以下行。
android:exported="true"
此标签确保你可以在应用中打开此 "Activity"(活动)或屏幕。有关此标签及其他标签的更多信息,请查阅 Android 的 <activity> 参考文档。
默认情况下,你的 AndroidManifest.xml 将位于 android/app/src/main/AndroidManifest.xml。
更新 Gradle Google Services 插件
在 android/build.gradle 文件中,将 classpath 'com.google.gms:google-services:4.3.5' 更改为 classpath 'com.google.gms:google-services:4.3.13' 以更新 Google Services 插件。
升级到 Gradle 7
在 File > Project Structure > Project 中调整 Gradle 项目设置。Android Gradle 插件版本应为 7.2.1 或更高,Gradle 版本应为 7.4.2 或更高。应用这些更改,然后点击 Android Studio 右上角的大象图标运行 gradle 同步。
Android Studio 可能会提供自动迁移到 Gradle 7 的选项。请接受这个提议!要升级,请转到你的 build.gradle 文件,点击 💡 图标,然后点击 "Upgrade Gradle"。项目迁移完成后,按照上述描述运行 gradle 同步。
另一种选择是使用 Android Gradle 插件升级助手来处理迁移。该工具的步骤可在 Android 文档 中找到。
确保使用 Java 11
Capacitor 3 兼容 Java 8 和 Java 11。从 Capacitor 4 开始,将仅支持 Java 11。你可以在 Android Studio 中通过以下菜单进行更改:
Preferences > Build, Execution, Deployment > Build Tools > Gradle

在那里,你可以将 "Gradle JDK" 修改为 Java 11。
Java 11 随最新版本的 Android Studio 一起提供。无需额外下载!
切换到自动 Android 插件 加载
这在 Capacitor 3 中是一个可选更改,但由于 init 方法已被移除,现在对于 Capacitor 4 升级来说是强制性的。在 MainActivity.java 中,onCreate 方法可以被移除。添加或删除通过 npm 安装的插件时,你不再需要编辑此文件。
public class MainActivity extends BridgeActivity {
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
-
- // Initializes the Bridge
- this.init(savedInstanceState, new ArrayList<Class<? extends Plugin>>() {{
- // Additional plugins you've installed go here
- add(Plugin1.class);
- add(Plugin2.class);
- }});
- }
}
更改 registerPlugin 顺序
如果你的应用包含专门为应用构建的自定义插件,必须在 super.onCreate 之前注册它们:
public class MainActivity extends BridgeActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
+ registerPlugin(PluginInMyApp.class);
super.onCreate(savedInstanceState);
- registerPlugin(PluginInMyApp.class);
}
}
可选:使用新的 Android 12 启动屏幕 API
要启用新的推荐 Android 12 启动屏幕 API,需要进行以下更改:
- 在
android/app/src/main/res/values/styles.xml中,将AppTheme.NoActionBarLaunch主题的parent属性从AppTheme.NoActionBar编辑为Theme.SplashScreen,并向主题添加所需的选项。
<style name="AppTheme.NoActionBarLaunch" parent="Theme.SplashScreen">
<item name="android:background">@drawable/splash</item>
</style>
不启用 Android 12 启动屏幕将导致 Android 12+ 设备上出现双启动屏幕,并在旧设备上使用旧的启动屏幕。
此更改是可选的,但建议执行,以防止在上次更改后 Android Studio 显示 Cannot resolve symbol 'Theme.SplashScreen' 消息。
- 在
android/app/build.gradle的依赖项部分添加implementation "androidx.core:core-splashscreen:$coreSplashScreenVersion"。### 可选:使用 DayNight 主题
若想基于用户设备主题自动切换深色/浅色主题,请将 android/app/src/main/res/values/styles.xml 文件中的 <style name="AppTheme.NoActionBar" parent="Theme.AppCompat.NoActionBar"> 替换为 <style name="AppTheme.NoActionBar" parent="Theme.AppCompat.DayNight.NoActionBar">。
可选:从 Gradle 文件中移除 jcenter()
在之前的 Capacitor 版本中,由于 Cordova 兼容层托管在 Jcenter 上,需要保留 jcenter()。但现在我们已使用托管在 Maven Central 上的最新 Cordova Android 版本。因此,您可能可以从 build.gradle 文件中完全移除 jcenter()。如果您使用了其他插件或原生依赖,请确保它们在移除前不依赖于 Jcenter!
插件
以下插件功能已被修改或移除,请相应更新您的代码。
Storage
@capacitor/storage 插件已更名为 @capacitor/preferences,以更好地反映其用途。API 保持不变。
Camera
- 移除了
preserveAspectRatio设置。 - 插件不再提示 iOS 使用说明缺失。
androidxMaterialVersion变量已更新至1.6.1。androidxExifInterfaceVersion变量已更新至1.3.3。
Action Sheet
ShowActionsOptions.title现在为可选参数。androidxMaterialVersion变量已更新至1.6.1。
仅限 iOS
buildActionSheet的标题和消息现在为可选参数。
Push Notifications
- 为
registrationError事件新增了RegistrationError类型。 importance现在为可选参数,默认值为3。deleteChannel现在仅接受频道 ID,而非整个对象。firebaseMessagingVersion变量已更新至23.0.5。- Android 现在支持
presentationOptions配置选项。
Local Notifications
importance现在为可选参数,默认值为3。deleteChannel现在仅接受频道 ID,而非整个对象。- Android 12 及以上版本需要权限才能发送精确通知。
App
App.exitApp()现在返回一个 Promise。
Geolocation
getCurrentPosition()现在忽略超时设置。playServicesLocationVersion已更新至20.0.0。- 当应用进入后台时,插件现在会停止位置更新。
- 如果系统定位服务被禁用,插件现在会抛出错误。
FileSystem
copy现在返回复制文件的路径。ReaddirResult现在返回一个FileInfo对象数组,除了文件的 URI 外,还包含每个文件的元数据。StatResult已统一,在所有平台上返回相同的内容。
Device
model现在在 iOS 上返回确切的型号(例如从“iPhone”改为“iPhone13.4”)。getLanguageCode()现在在 Web 上返回短语言代码(与其他平台一致),如需获取完整代码,请使用getLanguageTag()。
Dialog
title现在为可选参数。
Keyboard
style配置选项现在使用KeyboardStyle枚举作为选项。