从__CAPGO_KEEP_0__ 4更新到__CAPGO_KEEP_1__ 5:一步步指南
Capacitor

从Capacitor 4更新到Capacitor 5:一步步指南

了解如何以最小的破坏性更改更新您的项目,从Capacitor 4更新到Capacitor 5,包括更新官方插件和必需工具。

马丁·多纳迪厄

马丁·多纳迪厄

内容营销人员

从Capacitor 4更新到Capacitor 5:一步步指南

相比之前的更新,Capacitor 4 到 Capacitor 5 的过渡涉及最小的破坏性更改。这份指南提供了逐步的更新指南,帮助您将项目升级到 Capacitor 5,另外还列出了官方插件的破坏性更改。

注意:Capacitor 5 需要 NodeJS 16 或更高版本,因为 Node 12 已经到达了末端生命期,Node 14 将于 2023 年 4 月 30 日到达末端生命期。建议使用 NodeJS 的最新 LTS 版本。

  1. 安装项目中的 latest Capacitor CLI 的

    npm i -D @capacitor/cli@latest
  2. 运行以下命令,让 CLI 处理迁移:

    npx cap migrate

    如果任何迁移步骤无法实现,终端输出中将提供额外的信息。手动迁移步骤如下。

  3. 如果您安装了 VS Code 扩展,请检查扩展的建议部分,找到迁移项目到 Capacitor 5 的选项。

将 Capacitor 4 iOS 项目升级到 Capacitor 5

  1. 升级 Xcode:Capacitor 5 需要 Xcode 14.1+。

  2. 更新 .gitignore: 请对以下文件进行以下修改 .gitignore file:

    - App/Podfile.lock
    + App/output
  3. 更新 Assets 以使用单个应用图标: Xcode 14 支持单个应用图标的 1024x1024。清理 AppIcon.appiconset 中的所有不必要的大小。

将 Capacitor 4 个 Android 项目升级到 Capacitor 5

  1. 升级 Android Studio: Capacitor 5 需要 Android Studio Flamingo | 2022.2.1 或更高版本,因为它使用 Gradle 8,这需要 Java JDK 17。Java 17 与 Android Studio Flamingo 一起提供,因此不需要额外下载。

  2. 运行 AGP Upgrade 助手: Android Studio 可以帮助一些与 Gradle 和将包移动到构建文件相关的更新。要开始,请运行 Tools -> AGP Upgrade Assistant.

  3. 更新 Android 项目变量: 在您的 variables.gradle 文件中,更新您的值以以下新最低值:

    minSdkVersion = 22
    compileSdkVersion = 33
    targetSdkVersion = 33
    androidxActivityVersion = '1.7.0'
    androidxAppCompatVersion = '1.6.1'
    androidxCoordinatorLayoutVersion = '1.2.0'
    androidxCoreVersion = '1.10.0'
    androidxFragmentVersion = '1.5.6'
    coreSplashScreenVersion = '1.0.0'
    androidxWebkitVersion = '1.6.1'
    junitVersion = '4.13.2'
    androidxJunitVersion = '1.1.5'
    androidxEspressoCoreVersion = '3.5.1'
    cordovaAndroidVersion = '10.1.1'
  4. 更新 Google 服务:

    # build.gradle
    dependencies {
    -       classpath 'com.google.gms:google-services:4.3.13'
    +       classpath 'com.google.gms:google-services:4.3.15'
    }
  5. 更新 Gradle 插件到 8.0.0:

    # build.gradle
    dependencies {
    -       classpath 'com.android.tools.build:gradle:7.2.1'
    +       classpath 'com.android.tools.build:gradle:8.0.0'
    }
  6. 更新 Gradle 包装器到 8.0.2:

    # gradle-wrapper.properties
    distributionBase=GRADLE_USER_HOME
    distributionPath=wrapper/dists
    - distributionUrl=https\://services.gradle.org/distributions/gradle-7.4.2-all.zip
    + distributionUrl=https\://services.gradle.org/distributions/gradle-8.0.2-all.zip
    zipStoreBase=GRADLE_USER_HOME
    zipStorePath=wrapper/dists
  7. 禁用 Jetifier:

    # gradle.properties
    android.useAndroidX=true
    - android.enableJetifier=true
  8. 移动包到 build.gradle:

    # AndroidManifest.xml
    <?xml version="1.0" encoding="utf-8"?>
    - <manifest xmlns:android="http://schemas.android.com/apk/res/android"
    -     package="[YOUR_PACKAGE_ID]">
    + <manifest xmlns:android="http://schemas.android.com/apk/res/android">
    # build.gradle
    android {
    +     namespace "[YOUR_PACKAGE_ID]"
          compileSdkVersion rootProject.ext.compileSdkVersion
  9. 更新 androidScheme: 在 Capacitor 6 中 https 将成为 androidScheme for existing apps to better enable Capacitor applications to use the system Autofill feature. To avoid data loss as a result of this change, set the scheme to http 应用程序使用系统 Autofill 功能的能力。为了避免由于此更改而导致的数据丢失,请将方案设置为

    {
      server: {
        androidScheme: "http"
      }
    }
  10. 现在,即使它是当前默认值更新 Kotlin 版本 kotlin_version 变量到 '1.8.20'.

插件功能变更

以下插件功能已修改或删除。更新您的 code 以适应:

  • 动作面板
  • 浏览器
  • 相机
  • 设备
  • 地理位置
  • 谷歌地图
  • 本地通知
  • 推送通知
  • 状态栏

操作面板

  • 更新 androidxMaterialVersion __CAPGO_KEEP_0__ 1.8.0.

浏览器

  • 更新 androidxBrowserVersion __CAPGO_KEEP_0__ 1.5.0.

相机

  • 为了 Android 13,添加读取媒体图像权限(<uses-permission android:name="android.permission.READ_MEDIA_IMAGES"/>) 在 AndroidManifest.xml.
  • 更新 androidxMaterialVersion 更新 1.8.0.
  • __CAPGO_KEEP_0__ androidxExifInterfaceVersion __CAPGO_KEEP_0__ 1.3.6.

__CAPGO_KEEP_0__

  • __CAPGO_KEEP_1__ DeviceId.uuid __CAPGO_KEEP_2__ DeviceId.identifier.
  • __CAPGO_KEEP_3__ DeviceInfo.name 在 iOS 16+ 上, 除非您添加适当的.

__CAPGO_KEEP_4__

  • __CAPGO_KEEP_5__ playServicesLocationVersion __CAPGO_KEEP_6__ 21.0.1.

__CAPGO_KEEP_7__

  • __CAPGO_KEEP_8__
    • googleMapsPlayServicesVersion18.1.0.
    • googleMapsUtilsVersion3.4.0.
    • googleMapsKtxVersion3.4.0.
    • googleMapsUtilsKtxVersion3.4.0.
    • kotlinxCoroutinesVersion1.6.4.
    • androidxCoreKTXVersion1.10.0.
    • kotlin_version1.8.20.

本地通知

  • 为了 Android 13,需要在目标 SDK 33 时调用新的运行时权限检查来排程本地通知。 checkPermissions()requestPermissions() 因此

推送通知

  • 为了 Android 13,需要在目标 SDK 33 中添加一个新的运行时权限检查,以接收推送通知。调用 checkPermissions()requestPermissions() 相应地。
  • 更新 firebaseMessagingVersion 变量到 23.1.2.

状态栏

  • 在 iOS 上,已更改默认状态栏动画为 FADE.

按照这些步骤并更新您的 code,您应该现在已经成功地从 Capacitor 4 更新了您的项目到 Capacitor 5。确保测试您的应用程序,以确保所有功能和插件都按预期工作。

继续从 Updating from Capacitor 4 to Capacitor 5: A Step-by-Step Guide:一个步骤步骤指南

如果您正在使用 Updating from Capacitor 4 to Capacitor 5: A Step-by-Step Guide 来规划原生插件工作,连接它 Capgo 插件目录 在 Capgo 插件目录中了解产品工作流程 Capacitor 由 Capgo 提供的插件 了解 Capacitor 由 Capgo 提供的插件的实现细节 添加或更新插件 了解添加或更新插件的实现细节 Ionic Enterprise 插件替代方案 了解 Ionic Enterprise 插件替代方案的产品工作流程 Capgo 原生构建 了解 Capgo 原生构建的产品工作流程

Capacitor 实时更新

当 web 层 bug 活跃时,通过 Capgo 将修复推送给用户,而不是等待几天的 app store 审核。用户在后台接收更新,而原生变化保持在正常的审查路径中。

立即开始

最新博客文章

Capgo 为您提供创建真正专业的移动应用所需的最佳见解。