Introduction
Kamu sudah memiliki sebuah Aplikasi Web Progresif. Aplikasi tersebut berfungsi di browser, memiliki manifest, dan mungkin menggunakan service worker untuk dukungan offline. Jika kamu sekarang membutuhkan distribusi aplikasi di toko aplikasi, API perangkat native, atau funnel onboarding yang lebih baik, migrasi ke sebuah aplikasi Capacitor biasanya lebih cepat daripada merevisi frontend kamu.
Kelebihan terbesar adalah kamu dapat mempertahankan hampir semua web code yang sudah ada. Pada umumnya, kamu hanya perlu:
- membangun aset web produksi,
- menginisialisasi Capacitor dengan pengaturan yang tepat,
webDir, - menambahkan proyek iOS dan Android,
- dan menghubungkan plugin perangkat native hanya di tempat yang dibutuhkan.
Jika PWA kamu memiliki routing yang bersih dan logika komponen, ini dapat memakan waktu hanya beberapa jam.
Prasyarat
Waktu perkiraan: 2-5 jam, tergantung pada fitur spesifik platform.
- Node.js 18+ dengan Bun
- Sumber PWA Anda yang sudah ada code (React, Vue, Angular, Svelte, dll.)
- Xcode (hanya untuk iOS, macOS)
- Android Studio (hanya untuk Android)
- Akun Pengembang Apple jika Anda berencana untuk mempublikasikan iOS
- Akun Pengembang Google Play untuk distribusi Android
Langkah 1: Periksa PWA Anda sebelum mengelilinginya dengan native
Sebelum Anda menjalankan bunx cap init, pastikan aplikasi web Anda sudah siap produksi:
- Pastikan aplikasi PWA Anda memiliki skrip pembangunan produksi (misalnya,
bun run build). - Konfirmasikan folder keluaran web Anda adalah deterministik (seringkali
dist,build, atauout). - Hapus redirect absolut yang dikodekan secara keras yang mengasumsikan konteks browser-saja.
- Verifikasi perilaku pekerja layanan kompatibel dengan tampilan web mobile:
- Tetapkan dukungan offline jika itu membantu pengguna Anda.
- Hindari API browser-saja yang tidak tersedia di tampilan webview yang diintegrasikan.
- Konfirmasikan prompt instalasi PWA dan UX browser-saja masih relevan. Di aplikasi Capacitor biasanya tidak perlu prompt instalasi.
Langkah 2: Mengadaptasi perilaku web-saja
Tetapkan UI aplikasi Anda tetapi tutup logika browser-saja.
Gunakan pengecekan platform sederhana di sekitar prompt instalasi dan push:
import { Capacitor } from '@capacitor/core'
const isNative = Capacitor.isNativePlatform()
function registerInstallPrompt() {
if (isNative) return
// existing browser-only install or Web Push code
}
Hal ini menghindari logika browser-saja yang berjalan di dalam kontainer native.
Langkah 3: Inisialisasi Capacitor di folder PWA Anda
Dari root PWA yang sudah ada:
bun add @capacitor/core
bun add -D @capacitor/cli
Jalankan Capacitor init dengan nama aplikasi, ID aplikasi, dan direktori output web:
bunx cap init MyPWAApp com.example.my-pwa-app --web-dir dist
Jika folder build Anda adalah build (Create React App) atau out (Next.js static export), ganti dist.
Tambahkan konfigurasi Capacitor dasar:
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
Langkah 4: Tambahkan platform native
Pasang paket native inti dan buat folder proyek:
bun add @capacitor/ios @capacitor/android
bunx cap add ios
bunx cap add android
Pada titik ini Capacitor telah membuat ios/ dan android/ folder. Sinkronisasi akan menyalin aset web yang dibangun ke kedua platform.
Langkah 5: Bangun aplikasi web Anda dan sinkronkan
Bangun PWA dan sinkronkan aset web:
bun run build
bunx cap sync
Sekarang buka proyek native:
bunx cap open ios
bunx cap open android
Dari Xcode atau Android Studio, hubungkan perangkat atau emulator dan jalankan.
Langkah 6: Perbaikan native setelah migrasi
Ini adalah tempat Anda mengganti fitur web hanya dengan API native di mana perlu:
- Pemberitahuan push ->
@capacitor/push-notifications - Penyimpanan kunci/nilai yang aman ->
@capacitor/preferences - Kamera / media ->
@capacitor/camera - Autentikasi biometrik ->
@capacitor-community/native-biometric(atau plugin pilihan Anda)
Untuk setiap plugin native baru:
- Pasang paket plugin
- Konfigurasi pengaturan plugin khusus
- Lakukan:
bunx cap sync
Lalu, buat ulang dan jalankan lagi.
Langkah 7: Periksa keseragaman toko aplikasi
Sebelum pengiriman:
- Uji tautan dalam dan routing (
/dan rute dalam) pada kedua platform. - Pastikan status bar, area aman, dan orientasi benar.
- Hapus metadata web yang tidak digunakan yang bertentangan dengan perilaku aplikasi (misalnya, prompt instalasi).
- Tetapkan pengaturan keamanan transportasi dan privasi aplikasi konsisten dengan kebijakan Anda.
- Tambahkan ikon aplikasi/splash untuk setiap platform.
Jika aplikasi Anda menggunakan OTA updates, pasanglah pipa rilis Anda dengan strategi pembaruan yang aman untuk native dan pertimbangkan Capgo untuk peluncuran dan rollback yang terkendali.
Daftar periksa akhir
- Beban web aplikasi dibangun dengan bersih (
bun run build) - Capacitor diinisialisasi dengan
webDir bunx cap add iosdanbunx cap add androidselesai- Aplikasi native berjalan pada perangkat nyata
- Jalur code hanya browser yang dikunci untuk perilaku native
- Saluran pembaruan dan aset toko aplikasi telah dikonfigurasi
Anda telah melakukan sebagian besar pekerjaan sulit ketika membangun PWA. Menggabungkannya dengan Capacitor memberikan Anda:
- Distribusi toko,
- Akses ke API native,
- Iterasi yang lebih cepat tanpa perlu melakukan ulang code secara penuh,
- Jalur pengembangan tunggal untuk tim web dan mobile.
Mulai dari alur ini, kemudian iterasi native-by-native berdasarkan analisis dan umpan balik pengguna.
Teruskan dari Mengubah PWA Anda menjadi Aplikasi Native dengan Capacitor
Jika Anda menggunakan Mengubah PWA Anda menjadi Aplikasi Native dengan Capacitor untuk merencanakan migrasi dan operasi perusahaan, hubungkannya dengan Capgo Enterprise untuk alur kerja produk di Capgo Enterprise, Alternatif Plugin Enterprise Ionic untuk alur kerja produk di Ionic Enterprise Plugin Alternatif Capgo Alternatif untuk alur kerja produk di Capgo Alternatif, Capgo Konsultasi untuk alur kerja produk di Capgo Konsultasi, dan Capgo Layanan Premium untuk alur kerja produk di Capgo Layanan Premium.