La mise en place des dépendances dans les Capacitor plugins peut sembler écrasant, mais c'est plus facile lorsqu'on les divise en étapes claires. Voici ce qu'il vous faut savoir :
-
Comprendre les outils:
-
Configurez votre environnement de développement:
- Installez des outils comme Node.js, npm, Xcode, Android Studio, CocoaPods, et JDK.
-
Démarrer votre Capacitor projet de plugin:
- Utilisez
npm init @capacitor/pluginpour créer un nouveau plugin.
- Utilisez
-
Ajoutez les dépendances JavaScript:
- Utilisez
npm installpour les dépendances de production et de développement. - Mettez à jour
package.jsonpour inclure les dépendances de pair comme@capacitor/core.
- Utilisez
-
Gérez les dépendances spécifiques au plateau:
- iOS: Configurez CocoaPods ou SPM avec des bibliothèques comme Alamofire ou SwiftyJSON.
- Android: Utilisez Gradle pour ajouter des dépendances comme Gson ou AppCompat.
-
Optimisez les performances:
- Fixez les versions, passez en revue les dépendances et résolvez les conflits pour garantir la stabilité.
-
Utilisez des outils comme Capgo pour les mises à jour en direct:
- Apportez des mises à jour instantanément sans passer par les revues de l'App Store.
Comparaison rapide des outils:
| Plateforme | Outil | Exemple de dépendance |
|---|---|---|
| JavaScript | npm | npm install lodash --save |
| iOS | CocoaPods/SPM | pod 'Alamofire', '~> 5.6.4' |
| Android | Gradle | implementation 'com.google.code.gson:gson:2.10.1' |
Pourquoi cela compteGérer efficacement les dépendances garantit que votre plugin fonctionne de manière fluide sur plusieurs plateformes, économise du temps et évite les erreurs. Découvrons les étapes plus en détail.
Comment créer un Capacitor plugin pour iOS/Android

Configuration de votre environnement de développement
Préparez votre configuration avec les outils nécessaires pour gérer Capacitor plugin les dépendances de manière efficace.
Outils de développement requis
Voici une liste d'outils dont vous aurez besoin :
| Outil | Version | Objectif |
|---|---|---|
| Node.js | 16.0.0+ | Environnement d'exécution JavaScript |
| npm | 8.0.0+ | Gestion de paquets |
| Xcode | 14.0+ | Développement iOS (Mac uniquement) |
| Android Studio | Electric Eel+ | Développement Android |
| CocoaPods | 1.11.0+ | Gestion de dépendances iOS |
| JDK | 11+ | Outils de construction Android |
Lancement d'un nouveau plugin
Utilisez les Capacitor CLI pour démarrer votre projet de plugin. Cela inclut la configuration des plateformes et la nomination de votre plugin en utilisant un format de domaine inversé (par exemple, com.mycompany.plugin):
- Exécutez la commande suivante :
npm init @capacitor/plugin - Choisissez vos plateformes cibles (iOS/Android).
- Attribuez un nom à votre plugin en format de domaine inversé.
Étapes de configuration du projet
-
Mise à jour
package.jsonModifiez votre
package.jsonpour y inclure les éléments suivants :{ "capacitor": { "ios": { "src": "ios" }, "android": { "src": "android" } }, "peerDependencies": { "@capacitor/core": "^5.0.0" } } -
Configuration de la plateforme spécifique
-
Pour __CAPGO_KEEP_0__Assurez-vous que votre fichier Podfile comporte :
platform :ios, '13.0' use_frameworks! -
Pour __CAPGO_KEEP_0__Vérifiez que votre
build.gradlecontient :android { compileSdkVersion 33 defaultConfig { minSdkVersion 22 } }
-
-
Configurer les variables d'environnement suivantes pour vos outils de développement :
Variable
Objectif Valeur d'exemple Example Value ANDROID_HOME Emplacement d'Android SDK /Users/username/Library/Android/sdk JAVA_HOME Chemin d'installation de JDK /Library/Java/JavaVirtualMachines/jdk-11.0.12.jdk/Contents/Home XCODE_SELECT Outils de ligne de commande Xcode /Applications/Xcode.app/Contents/Developer
Une fois votre projet configuré, vous êtes prêt à passer à la gestion des dépendances JavaScript.
Dépendances JavaScript
La gestion efficace des dépendances JavaScript est essentielle pour maintenir une performance stable des plugins.
npm Installation de package

Pour installer les dépendances, utilisez les commandes suivantes :
# Add a production dependency
npm install lodash --save
# Add a development dependency
npm install @types/lodash --save-dev
Assurez-vous d'inclure manuellement les dépendances de peer dans votre package.json fichier. Testez toutes les dépendances pour confirmer la compatibilité sur les deux plateformes web et natives.
Gestion de package.json
Voici un exemple package.json de configuration :
{
"name": "my-capacitor-plugin",
"version": "1.0.0",
"dependencies": {
"lodash": "^4.17.21"
},
"devDependencies": {
"@types/lodash": "^4.14.195",
"@capacitor/core": "^5.0.0"
},
"peerDependencies": {
"@capacitor/core": "^5.0.0"
}
}
Pour maintenir la cohérence, bloquez les versions des dépendances de manière appropriée :
| Type de contrainte | Exemple | Utilisation |
|---|---|---|
| Exactement | “5.0.0” | Pour les dépendances critiques nécessitant une version spécifique |
| Caret | “^5.0.0” | Permet des mises à jour mineures et des correctifs |
| Tilde | “~5.0.0” | Restreint les mises à jour aux correctifs seulement |
Utilisation de bibliothèques JavaScript
Lors de l'importation de bibliothèques, concentrez-vous sur la réduction de la taille du bundle :
// Import only the required function
import { isEqual } from 'lodash';
export class MyPlugin {
async compare(options: { value1: any, value2: any }): Promise<boolean> {
return isEqual(options.value1, options.value2);
}
}
Assurez-vous également d'une gestion des erreurs et d'une vérification de type appropriées :
import { Plugin } from '@capacitor/core';
import { validate } from 'your-validation-library';
@Plugin({
name: 'MyPlugin',
platforms: ['web', 'ios', 'android']
})
export class MyPlugin {
async validateData(data: unknown): Promise<void> {
try {
if (!validate(data)) {
throw new Error('Invalid data format');
}
// Continue processing if valid
} catch (error) {
throw new Error(`Validation failed: ${error.message}`);
}
}
}
Prochainement, découvrez comment gérer les dépendances spécifiques à la plateforme pour iOS.
Dépendances iOS
Cette section explique comment gérer les dépendances natives iOS dans CapacitorUne fois que vous avez configuré vos dépendances JavaScript, le prochain pas consiste à gérer les dépendances natives iOS.
CocoaPods Configuration

Commencez par initialiser CocoaPods dans votre répertoire iOS :
cd ios
pod init
Ensuite, mettez à jour votre Plugin.podspec fichier avec les configurations suivantes :
Pod::Spec.new do |s|
s.name = 'MyCapacitorPlugin'
s.version = '1.0.0'
s.summary = 'Your plugin description'
s.platform = :ios, '13.0'
s.dependency 'Capacitor'
# Include your iOS dependencies here
s.dependency 'Alamofire', '~> 5.6.4'
end
Configuration de Podfile
Après avoir initialisé CocoaPods, configurez le Podfile pour inclure Capacitor et toute autre bibliothèque tiers supplémentaire :
platform :ios, '13.0'
use_frameworks!
def capacitor_pods
pod 'Capacitor', :path => '../../node_modules/@capacitor/ios'
pod 'CapacitorCordova', :path => '../../node_modules/@capacitor/ios'
end
target 'Plugin' do
capacitor_pods
# Add third-party dependencies
pod 'KeychainAccess', '~> 4.2.2'
pod 'SwiftyJSON', '~> 5.0.1'
end
target 'PluginTests' do
capacitor_pods
end
Voici quelques modèles de configuration de dépendance courants :
| Type de Contrainte | Exemple | Utilisation |
|---|---|---|
| Version Exacte | pod 'KeychainAccess', '4.2.2' |
Lorsque le contrôle précis est nécessaire, comme pour les composants de sécurité |
| Version Mineure | pod 'Alamofire', '~> 5.6' |
Pour les APIs stables qui peuvent recevoir des mises à jour de patch |
| Version Majeure | pod 'SwiftyJSON', '> 5.0' |
Lorsque la flexibilité à travers les mises à jour est acceptable |
Dépendances de Packages Swift
Si vous préférez ne pas utiliser CocoaPods, le gestionnaire de packages Swift (SPM) est une bonne alternative. Ajoutez les dépendances SPM directement dans Xcode avec la configuration suivante dans votre fichier : Package.swift Lorsque le contrôle précis est nécessaire, comme pour les composants de sécurité
// Package.swift
dependencies: [
.package(url: "https://github.com/Alamofire/Alamofire.git", .upToNextMajor(from: "5.6.4")),
.package(url: "https://github.com/SwiftyJSON/SwiftyJSON.git", from: "5.0.1")
]
Pour utiliser les dépendances SPM dans votre plugin code, importez-les et intégrez-les comme nécessaire. Par exemple :
import Capacitor
import Alamofire
@objc(MyPlugin)
public class MyPlugin: CAPPlugin {
@objc func makeRequest(_ call: CAPPluginCall) {
AF.request("https://api.example.com/data").response { response in
// Process the response
call.resolve([
"data": response.data
])
}
}
}
Cette approche vous permet de choisir entre CocoaPods et Swift Package Manager en fonction des besoins de votre projet.
Dépendances Android
Configurez les dépendances Android pour garantir une intégration native fluide. Voici comment gérer les dépendances pour votre plugin Capacitor.
Gradle Dépendances

Ajoutez les configurations suivantes à votre build.gradle fichier :
android {
defaultConfig {
minSdkVersion 22
targetSdkVersion 33
}
}
dependencies {
implementation "androidx.appcompat:appcompat:1.6.1"
implementation "com.google.code.gson:gson:2.10.1"
implementation "org.jetbrains.kotlin:kotlin-stdlib:1.8.20"
implementation project(':capacitor-android')
}
Définissez des versions supplémentaires dans le buildscript Bloc :
buildscript {
ext {
androidxCoreVersion = '1.10.1'
kotlinVersion = '1.8.20'
}
}
Une fois les dépendances configurées, assurez-vous de configurer les répositories nécessaires.
Configuration du Répertoire
Dans votre niveau de projet build.gradle, incluez les référentiels Maven requis :
allprojects {
repositories {
google()
mavenCentral()
maven { url "https://jitpack.io" }
}
}
Si vous utilisez des référentiels Maven personnalisés ou privés, ajoutez des informations d'identification comme suit :
maven {
url "https://maven.example.com/releases"
credentials {
username = project.findProperty("mavenUsername") ?: System.getenv("MAVEN_USERNAME")
password = project.findProperty("mavenPassword") ?: System.getenv("MAVEN_PASSWORD")
}
}
Une fois les référentiels configurés, résolvez les conflits de dépendances qui peuvent survenir.
Résolution des Problèmes deCompatibilité
Pour gérer les conflits de dépendances, appliquez des résolutions de versions dans votre build.gradle:
configurations.all {
resolutionStrategy {
force "org.jetbrains.kotlin:kotlin-stdlib:1.8.20"
force "androidx.core:core-ktx:1.10.1"
}
}
Ces sont des stratégies pour résoudre les problèmes de dépendances courants :
| Type de problème | Stratégie | Exemple |
|---|---|---|
| Conflit de version | Forcer une version spécifique | force 'com.google.code.gson:gson:2.10.1' |
| Versions multiples | Exclure un module | exclude group: 'org.json', module: 'json' |
| Problèmes transitatifs | Utiliser des versions strictes | strictly 'androidx.core:core-ktx:1.10.1' |
Par exemple, vous pouvez exclure des modules en conflit comme ceci :
dependencies {
implementation('library:name:1.0.0') {
exclude group: 'com.conflicting.dependency'
}
}
Finalement, optimisez votre processus de construction en activant la mise en cache et l'exécution parallèle dans gradle.properties:
org.gradle.caching=true
org.gradle.parallel=true
org.gradle.jvmargs=-Xmx2048m
Capgo Intégration

L'utilisation de Capgo aux côtés de la gestion de dépendances native et JavaScript rend l'actualisation de votre plugin plus rapide et plus facile.
À propos de Capgo
Capgo est une plateforme d'actualisation en temps réel conçue pour les Capacitor plugins et applications. [1]Capgo permet aux développeurs de pousser des mises à jour pour les dépendances et les code instantanément - aucune revue de l'App Store n'est requise.
Capgo Update Features
Capgo Mises à jour
| __CAPGO_KEEP_0__ simplifie la gestion des dépendances des plugins avec ces fonctionnalités : | Caractéristique | Ce qu'il fait |
|---|---|---|
| Indicateur clé | Mises à jour en temps réel | Envoyez des mises à jour en quelques minutes |
| Taux d'actualisation utilisateur de 95 % en 24 heures | Mises à jour partielles | 434ms average API response time |
| Contrôle de version | Gérer plusieurs versions | Taux de réussite mondial : 82% |
| Système de canal | Cibler des groupes d'utilisateurs spécifiques | Supporte plusieurs canaux de déploiement |
Source : [1]
Capgo fonctionne de manière fluide avec les outils CI/CD comme GitHub Actions, GitLab CI et Jenkins, automatisant les mises à jour de dépendances et garantissant des versions de plugins cohérentes. Ces outils facilitent l'intégration de Capgo dans votre flux de travail.
Configuration de Capgo
Suivez ces étapes pour intégrer Capgo dans votre projet :
-
Installer le Capgo CLI
Exécutez la commande suivante dans votre terminal :
npx @capgo/cli init -
Configurez les préférences de mise à jour
Utilisez le tableau de bord Capgo pour configurer les canaux et les préférences de déploiement. Les deux configurations hébergées dans le cloud et auto-hébergées sont prises en charge.
-
Ajoutez la logique de mise à jour
Ajoutez ce code à votre fichier de plugin principal pour activer les mises à jour :
import { Capgo } from '@capgo/capacitor-updater'; // Initialize Capgo const capgo = new Capgo({ appId: 'YOUR_APP_ID', channel: 'production' }); // Check for updates await capgo.checkForUpdate();
“Nous pratiquons le développement agile et @Capgo est essentiel à la livraison continue à nos utilisateurs !” - Rodrigo Mantica
Capgo fournit également un tableau de bord d'analyse pour des informations en temps réel sur les taux de réussite des mises à jour et l'activité des utilisateurs. Les fonctionnalités comme le retour en arrière en un clic et la traçabilité des erreurs aident à résoudre rapidement les problèmes, garantissant que vos mises à jour de plugin fonctionnent sans heurt.
Conclusion
Révision du processus
Gérer les dépendances pour les plugins Capacitor implique d'aligner les composants natifs (iOS et Android) avec leurs homologues JavaScript pour garantir une intégration fluide. Ce processus comprend des paramétrages spécifiques aux plateformes et la gestion de packages JavaScript pour atteindre la meilleure performance. Suivre les étapes décrites aidera à maintenir une fonctionnalité de plugin stable et efficace.
Meilleures pratiques
Pour gérer efficacement les dépendances, considérez ces pratiques :
| Pratique | Avantages | Comment mettre en œuvre |
|---|---|---|
| Fixation de version | Évite les problèmes inattendus | Utilisez des versions fixes dans package.json |
| Isolation de plateforme | Minimise les conflits | Dépendances natives séparées |
| Mises à jour régulières | Améliore la sécurité | Appliquez les correctifs critiques avec promptitude |
| Dépendances d'audit | Détection de risques | Exécuter npm audit fréquemment |
En utilisant des outils d'actualisation en temps réel comme Capgo peut simplifier et améliorer ces pratiques en permettant des mises à jour en temps réel.
Capgo Benefits
Capgo simplifie le processus de gestion des dépendances tout en offrant une forte performance. Il atteint un impressionnant taux d'actualisation utilisateur de 95% en 24 heures et maintient un temps de réponse global __CAPGO_KEEP_0__ de and maintains a global API response time of . Avec une encryption de bout en bout, il garantit des mises à jour sécurisées qui répondent aux deux lignes directrices d'Apple et d'Android. Pour les équipes gérant plusieurs versions de plugins, le système de canal de __CAPGO_KEEP_0__ permet des déploiements ciblés pour des groupes d'utilisateurs spécifiques. [1]Voici un aperçu rapide des performances de Capgo :
Voici un aperçu rapide des performances de Capgo :
| Indicateur | Valeur |
|---|---|
| Temps de réponse global API | 434ms |
| Taux de réussite de mise à jour | 82% |
| Taux d'actualisation des utilisateurs (24 heures) | 95% |
Continuez de la section Comment ajouter des dépendances dans les Capacitor Plugins
Si vous utilisez Comment ajouter des dépendances dans les Capacitor Plugins pour planifier le travail de plugin natif, connectez-le avec Capgo Répertoire des plugins pour le flux de travail du produit dans Capgo Répertoire des plugins, Capacitor Plugins par Capgo pour les détails d'implémentation dans Capacitor Plugins par Capgo, Ajout ou Mise à Jour de Plugins pour les détails d'implémentation dans Ajout ou Mise à Jour de Plugins, Alternatives de Plugins Entreprise Ionic pour le flux de travail du produit dans Alternatives de Plugins Entreprise Ionic, et Capgo Builds Natives pour le flux de travail du produit dans Capgo Builds Natives.