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

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

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

马丁·多纳迪厄

Martin Donadieu

内容营销

从 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 文件:

    - 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 即使是当前的默认值.

    {
      server: {
        androidScheme: "http"
      }
    }
  10. 更新 Kotlin 版本: 如果您的项目使用 Kotlin,更新 kotlin_version __CAPGO_KEEP_0__ '1.8.20'.

插件功能变更

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

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

操作面板

  • 更新 androidxMaterialVersion 变量为 1.8.0.

浏览器

  • 更新 androidxBrowserVersion 变量为 1.5.0.

相机

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

设备

  • 更改 DeviceId.uuidDeviceId.identifier.
  • 在 iOS 16+ 上 DeviceInfo.name 将返回一个通用设备名称,除非您添加适当的 地理位置.

更新

  • __CAPGO_KEEP_0__ playServicesLocationVersion21.0.1.

Google Maps

  • 更新以下变量:
    • 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。确保测试您的应用程序充分,以确保所有功能和插件都按预期工作。

实时更新Capacitor应用

当web层bug处于活跃状态时,通过Capgo将修复推送到用户,而不是等待几天的应用商店审批。用户在后台接收更新,而原生更改保持在正常审批路径中。

立即开始

博客最新文章

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