Vai direttamente al contenuto principale
Tutorial

Trasforma la tua App Web Progressiva in un'app nativa con Capacitor

Convert an existing Progressive Web App into a native Capacitor mobile app for iOS and Android. A practical guide to packaging your PWA with minimal code changes.

Martin Donadieu

Martin Donadieu

Content Marketer

Trasforma la tua App Web Progressiva in un'app nativa con Capacitor

Introduzione

Già hai una App Web Progressiva. Funziona nei browser, ha un manifesto e forse utilizza un worker di servizio per il supporto offline. Se ora hai bisogno di distribuzione negli store di app, di API di dispositivo nativo o di un funnel di onboarding migliore, migrare a un'app Capacitor è di solito più veloce che ricreare il front-end.

Il vantaggio più grande è che conservi quasi tutto il tuo web code esistente. In molti casi, hai bisogno solo di:

  • costruire asset web di produzione,
  • inizializzare Capacitor con le impostazioni giuste, webDir,
  • aggiungere progetti iOS e Android,
  • e collegare plugin nativi solo dove necessario.

Se la tua PWA ha percorsi puliti e logica di componente, ciò può richiedere solo poche ore.

Requisiti preliminari

Tempo stimato: 2-5 ore, a seconda delle caratteristiche specifiche del piattaforma.

  • Node.js 18+ con Bun
  • Il tuo codice PWA esistente code (React, Vue, Angular, Svelte, ecc.)
  • Xcode (solo per iOS e macOS)
  • Android Studio (solo per Android)
  • Un account di sviluppatore Apple se hai l'intenzione di pubblicare per iOS
  • Un account di sviluppatore Google Play per la distribuzione di Android

Passo 1: Controlla il tuo PWA prima di avvolgerlo in nativo

Prima di eseguire bunx cap init, verificare che il tuo'app web sia pronta per la produzione:

  1. Assicurati che il tuo PWA abbia uno script di build di produzione (ad esempio, bun run build).
  2. Conferma che il tuo cartello di output web è deterministico (spesso dist, build, o out).
  3. Elimina i redirect assoluti codificati che presuppongono un contesto browser-only.
  4. Verifica che il comportamento del worker di servizio sia compatibile con i WebViews mobili:
    • Conserva il supporto offline se aiuta i tuoi utenti.
    • Evita le API browser-only che non sono disponibili nel webview incorporato.
  5. Conferma che le richieste di installazione del PWA e l'interfaccia utente specifica del browser ancora hanno senso. In un'app Capacitor , le richieste di installazione del PWA sono di solito non necessarie.

Passo 2: Adatta i comportamenti web-only

Conserva la tua interfaccia utente dell'app ma blocca la logica browser-only.

Utilizza un controllo di piattaforma semplice intorno alle richieste di installazione e ai promemoria:

import { Capacitor } from '@capacitor/core'

const isNative = Capacitor.isNativePlatform()

function registerInstallPrompt() {
  if (isNative) return
  // existing browser-only install or Web Push code
}

Questo evita la logica browser-only che si attiva all'interno del contenitore nativo.

Passo 3: Inizializza Capacitor nella cartella della tua app PWA

Dalla radice della tua app PWA esistente:

bun add @capacitor/core
bun add -D @capacitor/cli

Esegui Capacitor init con il nome dell'app, l'ID bundle e il percorso di output web:

bunx cap init MyPWAApp com.example.my-pwa-app --web-dir dist

Se il tuo cartello di build è build (Create React App) o out (Next.js static export), sostituisci dist.

Aggiungi una configurazione base di Capacitor:

import type { CapacitorConfig } from '@capacitor/cli'

const config: CapacitorConfig = {
  appId: 'com.example.my-pwa-app',
  appName: 'MyPWAApp',
  webDir: 'dist',
  server: {
    iosScheme: 'https',
  },
}

export default config

Passo 4: Aggiungi piattaforme native

Installa i pacchetti nativi di base e genera cartelle di progetto:

bun add @capacitor/ios @capacitor/android
bunx cap add ios
bunx cap add android

In questo punto Capacitor ha creato ios/ e android/ cartelle. La sincronizzazione copierà i tuoi asset web costruiti in entrambe le piattaforme.

Passo 5: Costruisci l'app web e sincronizza

Costruisci la PWA e sincronizza gli asset web:

bun run build
bunx cap sync

Apri ora i progetti nativi:

bunx cap open ios
bunx cap open android

Da Xcode o Android Studio, collega un dispositivo o un emulatore e esegui.

Passo 6: Migrazione con miglioramenti nativi

Ecco dove sostituisci le funzionalità esclusivamente web con API native dove necessario:

  • Notifiche -> @capacitor/push-notifications
  • Archiviazione chiave/valore sicura -> @capacitor/preferences
  • Camera / media -> @capacitor/camera
  • Autenticazione biometrica -> @capacitor-community/native-biometric (o plugin di scelta)

Per ogni nuovo plugin nativo:

  1. Installa il pacchetto del plugin
  2. Configura le impostazioni specifiche del plugin
  3. Esegui:
bunx cap sync

Riavvia e esegui nuovamente.

Passo 7: Verifica della parità degli store dell'app

Prima della sottoscrizione:

  • Testa i collegamenti profondi e la navigazione (/ e percorsi profondi) su entrambe le piattaforme.
  • Verifica che lo stato della barra degli strumenti, le aree sicure e l'orientamento siano corretti.
  • Elimina i metadati web non utilizzati che confliggono con il comportamento dell'app (ad esempio, le richieste di installazione).
  • Mantieni le impostazioni di sicurezza dei trasporti e della privacy dell'app coerenti con la tua politica.
  • Aggiungi icone/splash per ogni piattaforma.

Se il tuo app utilizza aggiornamenti OTA, sincronizza la tua pipeline di rilascio con una strategia di aggiornamento sicura per i nativi e considera Capgo per un rilascio controllato e un rollback.

Elenco di controllo finale

  • I costrutti web si compilano puliti (bun run build)
  • Capacitor inizializzato con il giusto webDir
  • bunx cap add ios e bunx cap add android completato
  • Le app native funzionano su dispositivi reali
  • Le sole code per browser sono bloccate per il comportamento nativo
  • I canali di aggiornamento e gli asset per le app store sono configurati

Hai già fatto la maggior parte del lavoro duro quando hai costruito la tua PWA. Avvolgendo con Capacitor ti dà:

  • Distribuzione sullo store,
  • Accesso a API native,
  • Iterazione più veloce senza una completa code ricompilazione,
  • Un unico percorso di distribuzione per team web e mobili.

Inizia da questo flusso, poi iterare native-by-native in base a dati di analytics e feedback degli utenti.

Continua da Trasforma la tua PWA in un'app nativa con Capacitor

Se stai utilizzando Trasforma la tua PWA in un'app nativa con Capacitor per pianificare la migrazione e le operazioni aziendali, connettilo con Capgo Enterprise per il workflow del prodotto in Capgo Enterprise, Alternative per plugin Enterprise di Ionic per il flusso di lavoro del prodotto in Alternative per Ionic Enterprise Plugin Capgo Alternative per il flusso di lavoro del prodotto in Capgo Alternative, Capgo consulenza per il flusso di lavoro del prodotto in Capgo consulenza, e Capgo Supporto Premium per il flusso di lavoro del prodotto in Capgo Supporto Premium.

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 veramente professionale.