Pendahuluan
Anda sudah memiliki Aplikasi Web Progresif. Aplikasi ini berfungsi di browser, memiliki manifest, dan mungkin menggunakan service worker untuk dukungan offline. Jika Anda sekarang membutuhkan distribusi aplikasi toko, API perangkat native, atau funnel onboarding yang lebih baik, migrasi ke aplikasi Capacitor biasanya lebih cepat daripada merekonstruksi frontend Anda.
Kelebihan terbesar adalah Anda dapat menjaga hampir semua web code yang sudah ada. Dalam kebanyakan kasus, Anda hanya perlu:
- membangun aset web produksi,
- inisialisasi Capacitor dengan yang tepat
webDir, - tambahkan proyek iOS dan Android,
- dan hubungkan plugin native hanya di mana diperlukan.
Jika PWA Anda memiliki rute 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
- Your existing PWA source code (React, Vue, Angular, Svelte, etc.)
- Xcode (untuk iOS, macOS hanya)
- Studio Android (untuk Android)
- Jika Anda berencana untuk mempublikasikan iOS, Anda memerlukan akun pengembang Apple
- Untuk distribusi Android, Anda memerlukan akun pengembang Google Play
Langkah 1: Periksa PWA Anda sebelum menggabungkannya dengan native
Sebelum Anda menjalankan bunx cap init, pastikan aplikasi web Anda sudah siap produksi:
- Pastikan PWA Anda memiliki skrip pembangunan produksi (misalnya
bun run build). - Pastikan folder keluaran web Anda sudah menentukan (seringnya
dist,build, atauout). - Hapus redirect absolut yang dikodekan secara keras yang mengasumsikan konteks browser saja.
- Pastikan perilaku pekerjaan layanan kompatibel dengan mobile WebViews:
- Jika itu membantu pengguna Anda, simpan dukungan offline.
- Hindari API browser yang hanya tersedia di webview yang diintegrasikan.
- Konfirmasi prompt instalasi PWA dan UX browser yang spesifik masih relevan. Di aplikasi Capacitor biasanya tidak perlu prompt instalasi.
Langkah 2: Mengadaptasi perilaku web-only
Simpan antarmuka pengguna aplikasi Anda tetapi tutup logika browser-only.
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-only 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 direktori build Anda build (Create React App) atau out (Next.js static export), ganti dist.
Tambahkan konfigurasi dasar 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
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 sinkronisasi
Bangun PWA dan sinkronisasi 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: Pengembangan asli setelah migrasi
Ini adalah tempat Anda mengganti fitur web hanya dengan API asli di mana diperlukan:
- 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 asli baru:
- Pasang paket plugin
- Konfigurasi pengaturan spesifik plugin
- Jalankan:
bunx cap sync
Lalu, rekonstruksi dan jalankan lagi.
Langkah 7: Periksa kesetaraan toko aplikasi
Sebelum pengiriman:
- Uji tautan dalam dan routing (
/dan rute dalam) pada kedua platform. - Pastikan status bar, area yang 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/aset splash untuk setiap platform.
Jika aplikasi Anda menggunakan update OTA, pasirkan pipa rilis Anda dengan strategi update yang aman native dan pertimbangkan Capgo untuk peluncuran terkendali dan rollback.
Daftar periksa akhir
- Pembangunan aplikasi web bersih (
bun run build) - Capacitor diinisialisasi dengan cara yang tepat
webDir bunx cap add iosdanbunx cap add androidselesai- Aplikasi native berjalan pada perangkat nyata
- Jalur code hanya browser saja yang dikunci untuk perilaku native
- Saluran pembaruan dan aset toko aplikasi telah dikonfigurasi
Anda sudah melakukan sebagian besar pekerjaan sulit ketika membangun PWA. Menggabungkannya dengan Capacitor memberikan Anda:
- Distribusi toko
- Akses ke API native
- Iterasi yang lebih cepat tanpa harus merevisi code secara penuh
- Saluran pengembangan tunggal untuk tim web dan mobile
Mulai dari alur ini, kemudian iterasi native-by-native berdasarkan analisis dan umpan balik pengguna.