Aggiungere dipendenze a Capacitor I plugin __CAPGO_KEEP_0__ possono sembrare difficili da gestire, ma è più facile quando si suddividono in passaggi chiari. Ecco cosa devi sapere:
-
Capire gli strumenti:
- JavaScript: Utilizza
npmper gestire le dipendenze. - iOS: Utilizza CocoaPods o Swift Package Manager (SPM). Android
- : UtilizzaGradle per la gestione delle dipendenze. Configura il tuo ambiente di sviluppo Installa strumenti come
- JavaScript: Utilizza
-
Node.js:
- __CAPGO_KEEP_0__ Capacitor, npm, Xcode, Android Studio, CocoaPods e JDK., Avvia il tuo__CAPGO_KEEP_0__ progetto plugin
-
- Aggiungi dipendenze JavaScript
npm init @capacitor/pluginUsa
- Aggiungi dipendenze JavaScript
-
per le dipendenze di produzione e sviluppo.:
- Aggiorna
npm installper includere dipendenze peer come - Usa
package.jsonper le dipendenze di produzione e sviluppo.@capacitor/core.
- Aggiorna
-
Gestisci le dipendenze specifiche della piattaforma:
- iOS: Configura CocoaPods o SPM con librerie come Alamofire o SwiftyJSON.
- Android: Utilizza Gradle per aggiungere dipendenze come Gson o AppCompat.
-
Optimizza le prestazioni:
- Aggiorna le versioni, esegui un audit delle dipendenze e risolvi i conflitti per garantire la stabilità.
-
Utilizza strumenti come Capgo per aggiornamenti in tempo reale:
- Invia aggiornamenti istantaneamente senza revisioni di negozio di app.
Rapida comparazione di strumenti:
| Piattaforma | Strumento | Esempio di dipendenza |
|---|---|---|
| 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' |
Perché conta: Gestire efficacemente le dipendenze assicura che il tuo plugin funzioni senza problemi su più piattaforme, risparmi tempo e evita errori. Scopriamo di più in merito ai passaggi.
Come creare un Capacitor plugin per iOS/Android

Configurazione dell'ambiente di sviluppo
Prepara la tua configurazione con gli strumenti necessari per gestire Capacitor plugin le dipendenze in modo efficace.
Strumenti di sviluppo richiesti
Ecco una lista degli strumenti che avrai bisogno:
| Strumento | Versione | Fine |
|---|---|---|
| Ambiente di esecuzione Node.js | 16.0.0+ | Ambiente di esecuzione JavaScript |
| npm | 8.0.0+ | Gestione dei pacchetti |
| Xcode | 14.0+ | Sviluppo per iOS (solo Mac) |
| Android Studio | Electric Eel+ | Sviluppo Android |
| CocoaPods | 1.11.0+ | Gestione dipendenze iOS |
| JDK | 11+ | Strumenti di costruzione Android |
Avvio di un nuovo plugin
Utilizza i Capacitor CLI per avviare il tuo progetto plugin. Ciò include la configurazione delle piattaforme e il nome del tuo plugin utilizzando un formato di dominio inverso (ad esempio, com.mycompany.plugin):
- Esegui il seguente comando:
npm init @capacitor/plugin - Scegli le tue piattaforme di destinazione (iOS/Android).
- Assegna un nome al tuo plugin nel formato di dominio inverso.
Passaggi di configurazione del progetto
-
Aggiorna
package.jsonModifica il tuo
package.jsonper includere i seguenti:{ "capacitor": { "ios": { "src": "ios" }, "android": { "src": "android" } }, "peerDependencies": { "@capacitor/core": "^5.0.0" } } -
Configurazione Specifica per Piattaforma
-
Per iOS, assicurati che il tuo Podfile includa:
platform :ios, '13.0' use_frameworks! -
Per Android, verifica che il tuo
build.gradlecontenga:android { compileSdkVersion 33 defaultConfig { minSdkVersion 22 } }
-
-
Configura le variabili di ambiente seguenti per i tuoi strumenti di sviluppo:
Configura le seguenti variabili di ambiente per i tuoi strumenti di sviluppo:
Variabile Scopo Esempio di valore ANDROID_HOME Android SDK location /Users/username/Library/Android/sdk JAVA_HOME Percorso di installazione di JDK /Library/Java/JavaVirtualMachines/jdk-11.0.12.jdk/Contents/Home XCODE_SELECT Strumenti di riga di comando di Xcode /Applications/Xcode.app/Contents/Developer
Una volta che il tuo progetto è configurato, sei pronto a passare alla gestione delle dipendenze JavaScript.
Dipendenze JavaScript
La gestione efficace delle dipendenze JavaScript è fondamentale per mantenere le prestazioni stabili dei plugin.
npm Installazione del pacchetto

Per installare le dipendenze, utilizza i seguenti comandi:
# Add a production dependency
npm install lodash --save
# Add a development dependency
npm install @types/lodash --save-dev
Assicurati di includere manualmente le dipendenze peer nel tuo package.json file. Verifica tutte le dipendenze per confermare la compatibilità su entrambi i piattaforme web e native.
Gestione di package.json
Ecco un esempio package.json di configurazione:
{
"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"
}
}
Per mantenere la coerenza, blocca le versioni delle dipendenze in modo appropriato:
| Tipo di vincolo | Esempio | Caso d'uso |
|---|---|---|
| Esatto | ”5.0.0” | Per le dipendenze critiche che richiedono una versione specifica |
| Caret | ”^5.0.0” | Consente aggiornamenti minori e patch |
| Tilde | ”~5.0.0” | Limita gli aggiornamenti alle patch solo |
Utilizzo di librerie JavaScript
Quando si importano librerie, si concentri sulla riduzione della dimensione del pacchetto:
// 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);
}
}
Inoltre, assicurati di gestire correttamente gli errori e le verifiche di tipo:
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}`);
}
}
}
Prossimamente, esplora come gestire le dipendenze specifiche della piattaforma per iOS.
Dipendenze iOS
Questa sezione spiega come gestire le dipendenze native di iOS in Capacitor pluginUna volta impostate le tue dipendenze JavaScript, il passo successivo è gestire le dipendenze native di iOS.
CocoaPods Configurazione

Inizia con l'inizializzare CocoaPods nella tua directory iOS:
cd ios
pod init
Poi, aggiorna il tuo Plugin.podspec file con le seguenti configurazioni:
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
Configurazione Podfile
Dopo l'inizializzazione di CocoaPods, configura il Podfile per includere Capacitor e qualsiasi altra libreria di terze parti:
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
Ecco alcuni modelli di configurazione di dipendenza comuni:
| Tipo di vincolo | Esempio | Utilizzo |
|---|---|---|
| Versione esatta | pod 'KeychainAccess', '4.2.2' | Quando è necessario un controllo preciso, come per i componenti di sicurezza |
| Versione minore | pod 'Alamofire', '~> 5.6' | Per API stabili che possono ricevere aggiornamenti di patch |
| Versione maggiore | pod 'SwiftyJSON', '> 5.0' | Quando è accettabile la flessibilità all'interno degli aggiornamenti |
Dipendenze del Pacchetto Swift
Se preferisci non utilizzare CocoaPods, Swift Package Manager (SPM) è un'alternativa valida. Aggiungi le dipendenze SPM direttamente in Xcode con la seguente configurazione nel tuo Package.swift file:
// 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")
]
Per utilizzare le dipendenze SPM nel tuo plugin code, importale e integrali come necessario. Ad esempio:
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
])
}
}
}
Questa approccio ti consente di scegliere tra CocoaPods e Swift Package Manager in base alle esigenze del tuo progetto.
Dipendenze Android
Configura le dipendenze Android per garantire un'integrazione nativa liscia. Ecco come gestire le dipendenze per il tuo plugin Capacitor.
Gradle Dipendenze

Aggiungi le seguenti configurazioni al tuo build.gradle file:
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')
}
Definisci versioni aggiuntive nel buildscript blocco:
buildscript {
ext {
androidxCoreVersion = '1.10.1'
kotlinVersion = '1.8.20'
}
}
Una volta configurate le dipendenze, assicurati di configurare i repository necessari.
Configurazione del Repository
Nel tuo livello di progetto build.gradle, includi i repository Maven richiesti:
allprojects {
repositories {
google()
mavenCentral()
maven { url "https://jitpack.io" }
}
}
Se stai utilizzando repository Maven personalizzati o privati, aggiungi le credenziali in questo modo:
maven {
url "https://maven.example.com/releases"
credentials {
username = project.findProperty("mavenUsername") ?: System.getenv("MAVEN_USERNAME")
password = project.findProperty("mavenPassword") ?: System.getenv("MAVEN_PASSWORD")
}
}
Con i repository configurati, risolvi eventuali conflitti di dipendenza che potrebbero sorgere.
Risoluzione di Problemi di Conformità
Per gestire i conflitti di dipendenza, applica risoluzioni di versione nel tuo build.gradle:
configurations.all {
resolutionStrategy {
force "org.jetbrains.kotlin:kotlin-stdlib:1.8.20"
force "androidx.core:core-ktx:1.10.1"
}
}
Ecco le strategie per risolvere i problemi di dipendenza comuni:
| Tipo di problema | Strategia | Esempio |
|---|---|---|
| Conflitto di Versione | Forzare una versione specifica | force 'com.google.code.gson:gson:2.10.1' |
| Multiple Versioni | Escludere un modulo | exclude group: 'org.json', module: 'json' |
| Problemi Transitivi | Usare versioni rigorose | strictly 'androidx.core:core-ktx:1.10.1' |
Per esempio, puoi escludere i moduli in conflitto in questo modo:
dependencies {
implementation('library:name:1.0.0') {
exclude group: 'com.conflicting.dependency'
}
}
Infine, ottimizza il processo di build abilitando il caching e l'esecuzione in parallelo in gradle.properties:
org.gradle.caching=true
org.gradle.parallel=true
org.gradle.jvmargs=-Xmx2048m
Capgo Integrazione

Utilizzando Capgo insieme alla gestione delle dipendenze native e JavaScript, l'aggiornamento del tuo plugin è più veloce e facile.
Su Capgo
Capgo è una piattaforma di aggiornamento in tempo reale progettata per i plugin e le app Capacitor. Con oltre 23,5 milioni di aggiornamenti consegnati su 750 app in produzione [1]Capgo consente ai developer di inviare aggiornamenti per le dipendenze e code istantaneamente - senza la necessità di una revisione dell'app store. Gli aggiornamenti sono protetti da crittografia end-to-end e rispettano entrambi i requisiti di conformità di Apple e Android.
Caratteristiche di Aggiornamento di Capgo
Capgo semplifica la gestione delle dipendenze dei plugin con queste caratteristiche:
| Caratteristica | Cosa fa | Metrica Chiave |
|---|---|---|
| Aggiornamenti in Tempo Reale | Invia aggiornamenti in minuti | 95% di aggiornamento degli utenti in 24 ore |
| Aggiornamenti parziali | Scarica solo i file modificati | 434ms di tempo medio di risposta di API |
| Controllo delle versioni | Gestisci più versioni | 82% di successo globale |
| Sistema dei canali | Scegli gruppi di utenti specifici | Supporta più canali di distribuzione |
Fonte: [1]
Capgo funziona in modo trasparente con strumenti CI/CD come GitHub Actions, GitLab CI e Jenkins, automatizzando gli aggiornamenti delle dipendenze e garantendo versioni plugin coerenti. Questi strumenti rendono più facile integrare Capgo nel tuo workflow.
Impostazione di Capgo
Segui questi passaggi per integrare Capgo nel tuo progetto:
-
Installa il Capgo CLI
Esegui il seguente comando nel tuo terminale:
npx @capgo/cli init -
Configura le Preferenze di Aggiornamento
Utilizza il dashboard di Capgo per configurare i canali di distribuzione e le preferenze. Sono supportate sia le configurazioni ospitate sul cloud che quelle auto-ospitate.
-
Aggiungi Logica di Aggiornamento
Aggiungi questo code al tuo file plugin principale per abilitare gli aggiornamenti:
import { Capgo } from '@capgo/capacitor-updater'; // Initialize Capgo const capgo = new Capgo({ appId: 'YOUR_APP_ID', channel: 'production' }); // Check for updates await capgo.checkForUpdate();
“Pratichiamo lo sviluppo agile e @Capgo è essenziale per consegnare continuamente ai nostri utenti!” - Rodrigo Mantica
Capgo fornisce anche un dashboard di analisi per ottenere informazioni in tempo reale sulle tassi di successo degli aggiornamenti e sull'attività degli utenti. Caratteristiche come il rollback a un clic e la tracciatura degli errori aiutano a risolvere qualsiasi problema velocemente, mantenendo gli aggiornamenti del tuo plugin in esecuzione in modo fluido.
Conclusione
Rivista del Processo
Gestione delle dipendenze per i plugin Capacitor prevede l'allineamento dei componenti nativi (iOS e Android) con i loro omologhi JavaScript per garantire un'integrazione fluida. Questo processo include configurazioni specifiche per piattaforma e gestione dei pacchetti JavaScript per ottenere le migliori prestazioni. Seguendo i passaggi indicati si può mantenere una funzionalità del plugin stabile ed efficiente.
Pratiche raccomandate
Per gestire le dipendenze in modo efficace, considerare queste pratiche:
| Pratica | Beneficio | Come implementare |
|---|---|---|
| Pinning della versione | Evita problemi inaspettati | Utilizza versioni fisse in package.json |
| Isolamento della piattaforma | Minimizza conflitti | Separazione delle dipendenze native |
| Aggiornamenti regolari | Migliora la sicurezza | Applica patch critici con urgenza |
| Audit delle dipendenze | Rileva i rischi | Esegui npm audit spesso |
L'utilizzo di strumenti di aggiornamento in tempo reale come Capgo può semplificare ulteriormente e migliorare queste pratiche consentendo aggiornamenti in tempo reale.
Capgo Benefits
Capgo semplifica il processo di gestione delle dipendenze mentre garantisce una prestazione forte. Raggiunge un'impressionante tasso di aggiornamento utente del 95% entro 24 ore e mantiene un tempo di risposta globale API di 434ms [1]Con la crittografia end-to-end, assicura aggiornamenti sicuri che rispettano sia le linee guida di Apple che quelle di Android. Per le squadre che gestiscono più versioni di plugin, il sistema di canali di Capgo consente deployment mirati per gruppi di utenti specifici.
Ecco un rapido sguardo alle prestazioni di Capgo.
| Metrica | Valore |
|---|---|
| Global API Response Time | 434ms |
| Tasso di Aggiornamento Riuscito | 82% |
| Tasso di Aggiornamento dell'Utente (24 Ore) | 95% |