Par rapport aux mises à jour précédentes, la transition de Capacitor 4 à Capacitor 5 implique des changements de rupture minimaux. Ce guide fournit des instructions étape par étape pour mettre à jour votre projet vers Capacitor 5, ainsi qu'une liste des changements de rupture pour les plugins officiels.
Note: Capacitor 5 nécessite NodeJS 16 ou supérieur, car Node 12 a atteint la fin de vie et Node 14 atteindra la fin de vie le 30 avril 2023. Il est recommandé d'utiliser la dernière version LTS de NodeJS.
-
Installez la
latestversion de la Capacitor CLI dans votre projet :npm i -D @capacitor/cli@latest -
Exécutez la commande suivante pour laisser la CLI gérer la migration :
npx cap migrateSi les étapes de migration ne peuvent pas être réalisées, des informations supplémentaires seront fournies dans la sortie de la console. Les étapes de migration manuelles sont listées ci-dessous.
-
Si vous avez l'extension VS Code installée, consultez la section recommandations de l'extension pour trouver l'option de migration de votre projet vers Capacitor 5.
Mettre à niveau le projet Capacitor 4 iOS vers Capacitor 5
-
Mettre à niveau Xcode: Capacitor 5 nécessite Xcode 14.1+.
-
Mettre à jour .gitignore: Faites les modifications suivantes à votre
.gitignorefile:- App/Podfile.lock + App/output -
Mettre à jour les Actifs pour utiliser une seule icône d'application: Xcode 14 prend en charge une seule icône d'application de 1024x1024. Nettoyez votre AppIcon.appiconset en supprimant toutes les tailles inutiles.
Upgrading Capacitor 4 Projet Android à Capacitor 5
-
Mettre à niveau Android Studio: Capacitor 5 nécessite Android Studio Flamingo | 2022.2.1 ou une version plus récente en raison de l'utilisation de Gradle 8, qui nécessite Java JDK 17. Java 17 est livré avec Android Studio Flamingo, il n'est donc pas nécessaire de télécharger quoi que ce soit de plus.
-
Démarrer l'Assistant de mise à niveau AGP: Android Studio peut aider avec certaines mises à jour liées à Gradle et au déplacement de packages dans les fichiers de build. Pour commencer, exécutez
Tools -> AGP Upgrade Assistant. -
Mettre à jour les variables du projet Android: Dans votre
variables.gradlefile, mettez à jour vos valeurs pour les nouveaux minimums suivants :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' -
Mise à jour des services Google:
# build.gradle dependencies { - classpath 'com.google.gms:google-services:4.3.13' + classpath 'com.google.gms:google-services:4.3.15' } -
Mettre à jour le plugin Gradle vers 8.0.0:
# build.gradle dependencies { - classpath 'com.android.tools.build:gradle:7.2.1' + classpath 'com.android.tools.build:gradle:8.0.0' } -
Mettre à jour le wrapper Gradle vers 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 -
Désactiver Jetifier:
# gradle.properties android.useAndroidX=true - android.enableJetifier=true -
Déplacer le package vers
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 -
Mettre à jour le schéma Android: Dans Capacitor 6,
httpssera la configuration par défaut pourandroidSchemepour les applications existantes afin de mieux permettre aux applications Capacitor d'utiliser la fonctionnalité d'Autofill du système. Pour éviter toute perte de données en raison de cette modification, définir le schéma surhttpmaintenant, même si c'est la configuration par défaut actuelle.{ server: { androidScheme: "http" } } -
Mettre à jour la version Kotlin: Si votre projet utilise Kotlin, mettez à jour le
kotlin_versionvariable à'1.8.20'.
Fonctionnalités de plugin modifiées
Les fonctionnalités suivantes du plugin ont été modifiées ou supprimées. Mettez à jour votre code en conséquence :
- Feuille de tâches
- Navigateur
- Appareil photo
- Appareil
- Localisation
- Cartes de Google
- Notifications locales
- Notifications Push
- Barre de statut
Feuille de dialogue
- Mettre à jour le
androidxMaterialVersionvariable à1.8.0.
Navigateur
- Mettre à jour le
androidxBrowserVersionvariable à1.5.0.
Caméra
- Pour Android 13, ajoutez la permission de lecture des images de médias (
<uses-permission android:name="android.permission.READ_MEDIA_IMAGES"/>) dansAndroidManifest.xml. - Mettre à jour le
androidxMaterialVersionvariable à1.8.0. - Mettre à jour le
androidxExifInterfaceVersionvariable à1.3.6.
Appareil
- Modifier
DeviceId.uuidàDeviceId.identifier. - Sur iOS 16+,
DeviceInfo.namerenverra un nom d'appareil générique à moins que vous n'ajoutiez les entitlements appropriés.
Localisation
- Mettre à jour le
playServicesLocationVersionà21.0.1.
Google Maps
- Mettez à jour les variables suivantes :
googleMapsPlayServicesVersionà18.1.0.googleMapsUtilsVersionà3.4.0.googleMapsKtxVersionà3.4.0.googleMapsUtilsKtxVersionà3.4.0.kotlinxCoroutinesVersionà1.6.4.androidxCoreKTXVersionà1.10.0.kotlin_versionà1.8.20.
Notifications locales
- Pour Android 13, une nouvelle vérification de permission d'exécution est requise pour planifier les notifications locales lorsque vous ciblez SDK 33. Appelez
checkPermissions()etrequestPermissions()en conséquence.
Notifications Push
- Pour Android 13, une nouvelle vérification de permission d'exécution est requise pour recevoir les notifications push lors de la cible SDK 33. Appel
checkPermissions()etrequestPermissions()conformément. - Mettre à jour la
firebaseMessagingVersionvariable à23.1.2.
Barre d'état
- Sur iOS, l'animation par défaut de la barre d'état a été modifiée en
FADE.
En suivant ces étapes et en mettant à jour votre code conformément, vous devriez maintenant avoir mis à jour votre projet à partir de Capacitor 4 vers Capacitor 5. Assurez-vous de tester votre application soigneusement pour vous assurer que toutes les fonctionnalités et les plugins fonctionnent comme prévu.
Continuez de la mise à jour de Mise à jour de Capacitor 4 à Capacitor 5 : Guide étape par étape
Si vous utilisez Mise à jour de Capacitor 4 à Capacitor 5 : Guide étape par étape pour planifier le travail de plugin natif, connectez-le avec Répertoire des plugins Capgo pour le flux de travail du produit dans le répertoire des plugins Capgo Capacitor Plugins par Capgo pour le détail d'implémentation dans les plugins Capacitor par Capgo, Ajout ou mise à jour des plugins pour le détail d'implémentation dans Ajout ou mise à jour des plugins, Alternatives de plugins Ionic Enterprise pour le flux de travail du produit dans les alternatives de plugins Ionic Enterprise, et Capgo Builds natifs pour le flux de travail du produit dans les builds natifs Capgo.