Saltare al contenuto principale

Come aggiungere le dipendenze nei plugin Capacitor

Impara a semplificare la gestione delle dipendenze nei plugin Capacitor su piattaforme diverse con passaggi pratici e migliori pratiche.

Martin Donadieu

Martin Donadieu

Content Marketer

Come aggiungere le dipendenze nei plugin Capacitor

Aggiungere le dipendenze a Capacitor I plugin possono sembrare sovraccarichi, ma è più facile quando vengono suddivisi in passaggi chiari. Ecco cosa devi sapere:

  1. Capisci gli strumenti:

    • JavaScript: Utilizza npm per gestire le dipendenze.
    • iOS: Utilizza CocoaPods o Swift Package Manager (SPM).
    • Android: Utilizza Gradle per la gestione delle dipendenze.
  2. Configura il tuo ambiente di sviluppo:

  3. Avvia il tuo Capacitor plugin project:

    • Utilizza npm init @capacitor/plugin per creare un nuovo plugin.
  4. Aggiungi dipendenze JavaScript:

    • Utilizza npm install per le dipendenze di produzione e sviluppo.
    • Aggiorna package.json per includere dipendenze peer come @capacitor/core.
  5. Gestisci dipendenze specifiche per piattaforma:

    • iOS: Configura CocoaPods o SPM con librerie come Alamofire o SwiftyJSON.
    • Android: Utilizza Gradle per aggiungere dipendenze come Gson o AppCompat.
  6. Optimizza le prestazioni:

    • Pin le versioni, esegui un audit delle dipendenze e risolvi i conflitti per garantire la stabilità.
  7. Utilizza strumenti come Capgo per aggiornamenti in tempo reale:

    • Aggiorna in modo istantaneo senza revisioni dell'app store.

Rapida comparazione degli strumenti:

PiattaformaStrumentoEsempio di Dipendenza
JavaScriptnpmnpm install lodash --save
iOSCocoaPods/SPMpod 'Alamofire', '~> 5.6.4'
AndroidGradleimplementation 'com.google.code.gson:gson:2.10.1'

Perché è importante: Gestire le dipendenze in modo efficace assicura che il tuo plugin funzioni in modo fluido su tutte le piattaforme, risparmia tempo e evita errori. Scopriamo di più in merito ai passaggi.

Come creare un Capacitor plugin per iOS/Android

Capacitor Documentazione del Framework Sito Web

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 di cui avrai bisogno:

StrumentoVersioneFunzione
Node.js16.0.0+ambiente di esecuzione di JavaScript
npm8.0.0+Gestione dei pacchetti
Xcode14.0+Sviluppo per iOS (solo Mac)
Android StudioElectric Eel+Sviluppo per Android
CocoaPods1.11.0+Gestione delle dipendenze per iOS
JDK11+Strumenti di costruzione per Android

Avvio di un nuovo plugin

Utilizza i Capacitor CLI per avviare il tuo progetto di plugin. Ciò include la configurazione delle piattaforme e il nome del tuo plugin utilizzando un formato di denominazione inversa (ad es. com.mycompany.plugin):

  1. Esegui il seguente comando:
    npm init @capacitor/plugin
  2. Scegli le piattaforme di destinazione (iOS/Android).
  3. Assegna un nome al tuo plugin nel formato reverse-domain.

Passaggi di configurazione del progetto

  1. Aggiorna package.json

    Modifica il tuo package.json per includere i seguenti elementi:

    {
      "capacitor": {
        "ios": {
          "src": "ios"
        },
        "android": {
          "src": "android"
        }
      },
      "peerDependencies": {
        "@capacitor/core": "^5.0.0"
      }
    }
  2. Configurazione della piattaforma specifica

    • Per iOS, assicurati che il tuo Podfile includa:

      platform :ios, '13.0'
      use_frameworks!
    • Per Android, verificare il tuo build.gradle contiene:

      android {
          compileSdkVersion 33
          defaultConfig {
              minSdkVersion 22
          }
      }
  3. Impostazione delle variabili di ambiente

    Configura le seguenti variabili di ambiente per i tuoi strumenti di sviluppo:

    VariabileFineEsempio di valore
    ANDROID_HOMEPosizione di Android SDK/Users/username/Library/Android/sdk
    JAVA_HOME Percorso di installazione JDK/Library/Java/JavaVirtualMachines/jdk-11.0.12.jdk/Contents/Home
    XCODE_SELECTStrumenti di riga di comando di Xcode/Applications/Xcode.app/Contents/Developer

Una volta configurato il tuo progetto, sei pronto a passare alla gestione delle dipendenze JavaScript.

Dipendenze JavaScript

La gestione efficace delle dipendenze JavaScript è fondamentale per mantenere le prestazioni stabili del plugin.

npm Installazione del pacchetto

npm

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 file. package.json Testa tutte le dipendenze per confermare la compatibilità su entrambi i piattaforme web e native.

Gestione di package.json

Ecco un esempio di configurazione: package.json Per mantenere la consistenza, blocca le versioni delle dipendenze in modo appropriato:

{
  "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"
  }
}

Tipo di vincolo

Esempio di utilizzoUtilizzoPer le dipendenze critiche che richiedono una versione specifica
Caret”5.0.0”^
Per le dipendenze che richiedono una versione specifica”^5.0.0”Consente aggiornamenti minimi e patch
Tilde”~5.0.0”Limita gli aggiornamenti ai patch soltanto

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 di eseguire il controllo 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}`);
    }
  }
}

Prossimo passo, esplora come gestire le dipendenze specifiche per la piattaforma iOS.

Dipendenze iOS

Questa sezione spiega come gestire le dipendenze native iOS in Capacitor pluginUna volta impostate le dipendenze JavaScript, il passo successivo è gestire le dipendenze native iOS.

CocoaPods Configurazione

CocoaPods

Inizia configurando CocoaPods nella tua directory iOS:

cd ios
pod init

Aggiorna poi 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 del Podfile

Dopo aver iniziato a configurare 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 comuni per le dipendenze:

Tipo di vincoloEsempioUtilizzo
Versione esattapod 'KeychainAccess', '4.2.2'Quando è necessario un controllo preciso, come per i componenti di sicurezza
Versione Minorepod 'Alamofire', '~> 5.6'Per API stabili che potrebbero ricevere aggiornamenti di patch
Versione Maggiorepod 'SwiftyJSON', '> 5.0'Quando è accettabile la flessibilità all'interno degli aggiornamenti

Dipendenze del Package Swift

Se preferite non utilizzare CocoaPods, il Manager dei Pacchetti Swift (SPM) è un'alternativa valida. Aggiungere 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, importarle e integrarle 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 consente di scegliere tra CocoaPods e Manager dei Pacchetti Swift in base alle esigenze del tuo progetto

Dipendenze Android

Configurare le dipendenze Android per garantire un'integrazione nativa liscia. Ecco come gestire le dipendenze per il tuo plugin Capacitor

Gradle Dipendenze

Gradle Build Tool Interface

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 le repository necessarie.

Configurazione della Repository

Nel tuo livello di progetto build.gradle, includi le repository Maven richieste:

allprojects {
    repositories {
        google()
        mavenCentral()
        maven { url "https://jitpack.io" }
    }
}

Se stai utilizzando repository Maven personalizzati o privati, aggiungi le credenziali come segue:

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.

Risolvere Problemi di Conformità

Per gestire i conflitti di dipendenza, applica le risoluzioni di versione nei tuoi build.gradle:

configurations.all {
    resolutionStrategy {
        force "org.jetbrains.kotlin:kotlin-stdlib:1.8.20"
        force "androidx.core:core-ktx:1.10.1"
    }
}

Ecco alcune strategie per risolvere i problemi di dipendenza comuni:

Tipo di ProblemaStrategiaEsempio
Conflitto di VersioneForza una versione specificaforce 'com.google.code.gson:gson:2.10.1'
Versioni MultipleEscludi un moduloexclude group: 'org.json', module: 'json'
Problemi TrasversaliUsa versioni rigorosestrictly 'androidx.core:core-ktx:1.10.1'

Ad esempio, puoi escludere 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 la cache e l'esecuzione in parallelo in gradle.properties:

org.gradle.caching=true
org.gradle.parallel=true
org.gradle.jvmargs=-Xmx2048m

Capgo Integrazione

Capgo Dashboard di aggiornamento in tempo reale dell'interfaccia

Usando Capgo insieme alla gestione di dipendenze native e JavaScript rende più veloce e facile l'aggiornamento del tuo plugin.

Su Capgo

Capgo è una piattaforma di aggiornamento in tempo reale progettata per plugin e 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 i requisiti di conformità sia per Apple che per Android.

Caratteristiche di aggiornamento di Capgo

Capgo semplifica la gestione delle dipendenze dei plugin con queste caratteristiche:

FunzioneCosa faMetrica chiave
Aggiornamenti in tempo realeInvia aggiornamenti in pochi minutiTasso di aggiornamento utente del 95% entro 24 ore
Aggiornamenti parzialiScarica solo i file modificati434ms average API response time
Controllo delle versioniGestisci diverse versioniTasso di successo globale del 82%
Sistema dei canaliScegliere specifiche fasce di utentiSupporta più canali di distribuzione

Fonte: [1]

Capgo funziona in modo trasparente con strumenti CI/CD come GitHub Actions, GitLab CI e Jenkins, automatizzando l'aggiornamento delle dipendenze e garantendo versioni plugin coerenti. Questi strumenti rendono più facile integrare Capgo nel tuo workflow.

Configurazione di Capgo

Segui questi passaggi per integrare Capgo nel tuo progetto:

  1. Installa il Capgo CLI

    Esegui il seguente comando nel tuo terminale:

    npx @capgo/cli init
  2. 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 in cloud che quelle auto-ospitate.

  3. 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 in modo continuativo ai nostri utenti!' - Rodrigo Mantica

Capgo fornisce inoltre 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 con un clic e la tracciatura degli errori aiutano a risolvere qualsiasi problema velocemente, mantenendo gli aggiornamenti dei plugin in esecuzione in modo fluido.

Conclusioni

Revisione del processo

Gestire le dipendenze per i plugin Capacitor comporta l'allineamento dei componenti nativi (iOS e Android) con i loro omologhi JavaScript per garantire un'integrazione liscia. Questo processo include le impostazioni specifiche per piattaforma e la gestione dei pacchetti JavaScript per ottenere il miglior rendimento. Seguendo i passaggi descritti si potranno mantenere stabili e efficienti le funzionalità dei plugin.

Pratiche migliori

Per gestire le dipendenze in modo efficace, considera queste pratiche:

PraticaBeneficioCome implementare
Pinning della versioneEvita problemi imprevistiUtilizza versioni fisse in package.json
Isolamento della piattaformaMinimizza conflittiSeparare le dipendenze native
Aggiornamenti regolariMigliora la sicurezzaApplica patch critici in modo tempestivo
Valutazione delle dipendenzeRileva rischiEsegui npm audit frequentemente

Utilizzando 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 fornisce una forte prestazione. Raggiunge un'impressionante 95% di aggiornamenti degli utenti entro 24 ore e mantiene un tempo di risposta globale di API di 434ms [1]. Con crittografia end-to-end, assicura aggiornamenti sicuri che rispettano sia le linee guida di Apple che quelle di Android. Per gli 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:

MetricaValore
Tempo di risposta globale di API434ms
Tasso di Successo dell'Aggiornamento82%
Tasso di Aggiornamento degli Utenti (24 Ore)95%
Aggiornamenti in tempo reale per le app Capacitor

Quando un bug nel layer web è attivo, invia la correzione attraverso Capgo invece di attendere giorni per l'approvazione della store. Gli utenti ricevono l'aggiornamento in background mentre le modifiche native rimangono nel normale percorso di revisione.

Inizia subito

Ultimi articoli dal nostro Blog

Capgo ti offre le migliori informazioni che ti servono per creare un'app mobile davvero professionale.