Pendahuluan
Ingin membangun aplikasi mobile dengan Nuxt dari dasar? Panduan ini akan mengajak Anda melalui membuat proyek Nuxt 4 baru yang sudah terkonfigurasi untuk mobile dari hari pertama, kemudian mengemasnya sebagai aplikasi mobile asli iOS dan Android menggunakan Capacitor 8.
Setelah menyelesaikan tutorial ini, Anda akan memiliki aplikasi mobile yang berjalan di simulator yang dapat Anda lanjutkan mengembangkan dan akhirnya menerbitkan di App Store dan Google Play.
Waktu yang dibutuhkan: ~30 menit
Apa yang akan dibangun:
- Proyek Nuxt 4 baru dengan struktur direktori terbaru
- Konfigurasi penghasilan statis untuk mobile
- Capacitor 8 dengan plugin yang penting
- Aplikasi iOS dan Android native
- Pengaturan pengembangan live reload
Sudah memiliki aplikasi Nuxt? Cek Konversi Aplikasi Nuxt Anda ke Mobile sebaliknya.
Persyaratan
Pastikan Anda telah menginstal:
- Node.js 18+ Periksa dengan
node --version) - Bun manajer paket (
curl -fsSL https://bun.sh/install | bash) - Xcode (hanya untuk macOS, untuk pengembangan iOS)
- Android Studio (untuk pengembangan Android)
Langkah 1: Buat Projek Nuxt 4 Baru
Mulai dengan membuat projek Nuxt 4 segar:
bunx nuxi@latest init my-mobile-app
cd my-mobile-app
bun install
Struktur Direktori Nuxt 4
Nuxt 4 menggunakan struktur direktori baru dengan app code di direktori: app/ package manager (
my-mobile-app/
app/
assets/
components/
composables/
layouts/
middleware/
pages/
plugins/
utils/
app.vue
public/
server/
nuxt.config.ts
package.json
Struktur ini menyediakan pemisahan yang lebih baik antara aplikasi dan server code.
Langkah 2: Konfigurasi Nuxt untuk Pengembangan Statik
Capacitor memerlukan file HTML/JS/CSS statis. Konfigurasi Nuxt untuk pengembangan statik di nuxt.config.ts:
export default defineNuxtConfig({
compatibilityDate: '2025-01-15',
devtools: { enabled: true },
// Enable static generation
ssr: true,
nitro: {
preset: 'static',
},
});
Langkah 3: Tambahkan Skrip Mobile
Perbarui dengan skrip pengembangan mobile: package.json Uji pengembangan statik:
{
"scripts": {
"dev": "nuxt dev",
"build": "nuxt build",
"generate": "nuxt generate",
"preview": "nuxt preview",
"mobile": "bun run generate && bunx cap sync",
"mobile:ios": "bun run mobile && bunx cap open ios",
"mobile:android": "bun run mobile && bunx cap open android"
}
}
Anda seharusnya melihat sebuah
bun run generate
direktori dengan file statis Anda. .output/public Langkah 4: Pasang __CAPGO_KEEP_0__ 8
Pasang paket-paket inti Capacitor:
Install the Capacitor core packages:
bun add @capacitor/core
bun add -D @capacitor/cli
Pasang __CAPGO_KEEP_0__ 8 untuk pengembangan mobile:
bun add @capacitor/app @capacitor/keyboard @capacitor/splash-screen @capacitor/status-bar @capacitor/preferences
Apa yang dilakukan plugin ini:
- @capacitor/app — Acara siklus aplikasi (depan/belakang, tautan dalam)
- @capacitor/keyboard — Mengontrol perilaku keyboard
- @capacitor/splash-screen — Pengendalian layar splash native
- @capacitor/status-bar — Mengatur bar status perangkat
- @capacitor/preferences — Penyimpanan nilai kunci (seperti localStorage tetapi native)
Langkah 5: Inisialisasi Capacitor
Inisialisasi Capacitor dengan detail proyek Anda:
bunx cap init "My Mobile App" com.example.mymobileapp --web-dir .output/public
Ganti:
"My Mobile App"dengan nama tampilan aplikasi Andacom.example.mymobileappdengan ID aplikasi (notasi domain terbalik)
Hal ini menciptakan capacitor.config.ts. Perbarui dengan konfigurasi plugin:
import type { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
appId: 'com.example.mymobileapp',
appName: 'My Mobile App',
webDir: '.output/public',
plugins: {
SplashScreen: {
launchShowDuration: 2000,
launchAutoHide: true,
androidScaleType: 'CENTER_CROP',
splashFullScreen: true,
splashImmersive: true,
},
Keyboard: {
resize: 'body',
resizeOnFullScreen: true,
},
StatusBar: {
style: 'dark',
},
},
};
export default config;
Langkah 6: Tambahkan Platform Nativ
Pasang paket platform:
bun add @capacitor/ios @capacitor/android
Buat proyek native:
bunx cap add ios
bunx cap add android
Hal ini menciptakan ios dan android direktori yang berisi proyek native.
Langkah 7: Bangun dan Jalankan
Bangun proyek Anda dan sinkron dengan platform native:
bun run mobile
Buka di Simulator iOS:
bun run mobile:ios
Atau Emulator Android:
bun run mobile:android
Di Xcode (iOS):
- Pilih simulator dari dropdown perangkat
- Klik tombol Play atau tekan
Cmd + R
Di Android Studio:
- Tunggu Gradle selesai sinkron
- Pilih emulator dari dropdown perangkat
- Klik tombol Run atau tekan
Shift + F10
Langkah 8: Atur Ulang Reload Hidup
Untuk pengembangan yang lebih cepat, aktifkan ulang live reload sehingga perubahan akan muncul secara instan di perangkat Anda.
- Cari alamat IP lokal Anda:
# macOS
ipconfig getifaddr en0
# Windows
ipconfig
- Buat konfigurasi pengembangan Capacitor. Perbarui
capacitor.config.ts:
import type { CapacitorConfig } from '@capacitor/cli';
const devConfig: CapacitorConfig = {
appId: 'com.example.mymobileapp',
appName: 'My Mobile App',
webDir: '.output/public',
server: {
url: 'http://YOUR_IP_ADDRESS:3000',
cleartext: true,
},
plugins: {
// ... same plugin config
},
};
const prodConfig: CapacitorConfig = {
appId: 'com.example.mymobileapp',
appName: 'My Mobile App',
webDir: '.output/public',
plugins: {
// ... same plugin config
},
};
const config = process.env.NODE_ENV === 'development' ? devConfig : prodConfig;
export default config;
- Mulai server pengembangan dan salin konfigurasi ke native:
bun run dev &
NODE_ENV=development bunx cap copy
- Rebuild di Xcode/Android Studio
Sekarang edit pada Nuxt code akan hot-reload di perangkat.
Langkah 9: Buat Layar Mobile Pertama
Marilah kita buat layar home yang ramah mobile. Perbarui app/app.vue:
<template>
<NuxtPage />
</template>
Buat app/pages/index.vue:
<template>
<main
class="min-h-screen bg-linear-to-b from-green-500 to-green-700 flex flex-col items-center justify-center p-6 text-white"
>
<h1 class="text-4xl font-bold mb-4">My Mobile App</h1>
<p class="text-xl mb-8 text-center opacity-90">
Built with Nuxt 4 + Capacitor 8
</p>
<div v-if="appInfo" class="bg-white/20 rounded-lg p-4 backdrop-blur-sm mb-8">
<p class="text-sm">
{{ appInfo.name }} v{{ appInfo.version }}
</p>
</div>
<div class="space-y-4 w-full max-w-sm">
<button
class="w-full py-4 px-6 bg-white text-green-600 rounded-xl font-semibold text-lg shadow-lg active:scale-95 transition-transform"
@click="handleGetStarted"
>
Get Started
</button>
<button
class="w-full py-4 px-6 bg-white/20 text-white rounded-xl font-semibold text-lg backdrop-blur-sm active:scale-95 transition-transform"
@click="handleShare"
>
Share App
</button>
</div>
</main>
</template>
<script setup lang="ts">
import { ref, onMounted, onUnmounted } from 'vue';
import { App } from '@capacitor/app';
const appInfo = ref<{ name: string; version: string } | null>(null);
let backButtonListener: { remove: () => void } | null = null;
onMounted(async () => {
// Get app info
try {
appInfo.value = await App.getInfo();
} catch (e) {
// Web fallback
appInfo.value = { name: 'My Mobile App', version: '1.0.0' };
}
// Handle Android back button
backButtonListener = await App.addListener('backButton', ({ canGoBack }) => {
if (!canGoBack) {
App.exitApp();
} else {
window.history.back();
}
});
});
onUnmounted(() => {
backButtonListener?.remove();
});
function handleGetStarted() {
// Navigate to onboarding or main app
console.log('Get started clicked');
}
async function handleShare() {
// We'll implement this with the Share plugin later
console.log('Share clicked');
}
</script>
Langkah 10: Tambahkan Tailwind CSS
Untuk gaya yang berfungsi, tambahkan Tailwind CSS ke proyek Anda:
bun add tailwindcss @tailwindcss/vite
Perbarui nuxt.config.ts:
import tailwindcss from '@tailwindcss/vite';
export default defineNuxtConfig({
compatibilityDate: '2025-01-15',
devtools: { enabled: true },
ssr: true,
nitro: {
preset: 'static',
},
css: ['~/assets/css/main.css'],
vite: {
plugins: [tailwindcss()],
},
});
Buat app/assets/css/main.css:
@import 'tailwindcss';
:root {
--sat: env(safe-area-inset-top);
--sar: env(safe-area-inset-right);
--sab: env(safe-area-inset-bottom);
--sal: env(safe-area-inset-left);
}
body {
padding-top: var(--sat);
padding-right: var(--sar);
padding-bottom: var(--sab);
padding-left: var(--sal);
}
/* Prevent text selection on mobile */
* {
-webkit-user-select: none;
user-select: none;
-webkit-tap-highlight-color: transparent;
}
/* Allow text selection in inputs */
input,
textarea {
-webkit-user-select: auto;
user-select: auto;
}
Langkah 11: Tambahkan Plugin Berbagi
Mari kita implementasikan fungsi tombol berbagi:
bun add @capacitor/share
Perbarui app/pages/index.vue untuk menggunakan plugin Berbagi:
<script setup lang="ts">
import { ref, onMounted, onUnmounted } from 'vue';
import { App } from '@capacitor/app';
import { Share } from '@capacitor/share';
// ... existing code ...
async function handleShare() {
try {
await Share.share({
title: 'Check out this app!',
text: 'Built with Nuxt 4 and Capacitor 8',
url: 'https://capacitorjs.com',
dialogTitle: 'Share with friends',
});
} catch (e) {
console.log('Share cancelled or failed:', e);
}
}
</script>
Sinkron dan bangun kembali:
bun run mobile
Struktur Proyek
Proyek Anda seharusnya terlihat seperti ini:
my-mobile-app/
├── android/ # Android native project
├── ios/ # iOS native project
├── .output/
│ └── public/ # Static build output
├── app/
│ ├── assets/
│ │ └── css/
│ │ └── main.css
│ ├── pages/
│ │ └── index.vue
│ └── app.vue
├── capacitor.config.ts # Capacitor configuration
├── nuxt.config.ts # Nuxt configuration
├── package.json
└── ...
Langkah-Langkah Selanjutnya
Anda telah memiliki aplikasi mobile Nuxt yang berfungsi. Berikut adalah langkah-langkah selanjutnya:
Pengaturan Dasar
- Ikon Aplikasi: Ganti ikon default di
ios/App/App/Assets.xcassetsdanandroid/app/src/main/res - Splash Screen: Tentukan dalam proyek native atau gunakan
@capacitor/splash-screenkonfigurasi - Deep Links: Konfigurasi skema URL untuk aplikasi Anda
Tambahkan Fitur Lainnya
- Kamera:
bun add @capacitor/camera - Lokasi:
bun add @capacitor/geolocation - Pemberitahuan Push:
bun add @capacitor/push-notifications - Sistem File:
bun add @capacitor/filesystem
Perbaikan UI
Perlu mempertimbangkan untuk menambahkan Konsta UI untuk komponen iOS/Android yang terlihat asli:
bun add konsta
Maka update CSS Anda untuk mengimport tema:
@import 'tailwindcss';
@import 'konsta/theme.css';
Pembaruan Langsung Melalui Jaringan
Konfigurasi Capgo untuk memasang pembaruan tanpa harus mengirimkan aplikasi ke toko aplikasi lagi:
bunx @capgo/cli init
Pengaturan Masalah
Build gagal dengan “Cannot find module”
Jalankan bun install dan coba lagi.
iOS: “Tidak ditemukan identitas tanda tangan” Buka Xcode, pergi ke Signing & Capabilities, dan pilih tim pengembangan Anda.
Anda: “Lokasi SDK tidak ditemukan”
Buat android/local.properties dengan sdk.dir=/path/to/android/sdk
Perubahan tidak muncul di perangkat
Pastikan Anda menjalankan bun run mobile setelah membuat perubahan. Untuk live reload, verifikasi alamat IP yang benar dan server pengembangan berjalan.
.output/public kosong atau hilang
Pastikan Anda mengonfigurasi nitro: { preset: 'static' } di nuxt.config.ts dan menjalankan bun run generate.
Sumber Daya
Siap untuk mengirimkan aplikasi Anda? Pelajari bagaimana Capgo dapat membantu Anda mengirimkan update lebih cepat — daftar untuk akun gratis hari ini.
Teruskan dari Bangun Aplikasi Nuxt Mobile dari Awal dengan Capacitor 8
Jika Anda menggunakan Bangun Aplikasi Nuxt Mobile dari Awal dengan Capacitor 8 untuk merencanakan otomatisasi CI/CD, hubungkannya dengan Capgo Otomatisasi CI/CD untuk alur kerja produk di Capgo Otomatisasi CI/CD, Capgo Pembangunan Natively untuk alur kerja produk di Capgo Pembangunan Natively, Capgo Integrasi untuk alur kerja produk di Capgo Integrasi, Integrasi CI/CD untuk detail implementasi di Integrasi CI/CD, dan GitHub Integrasi Aksi untuk detail implementasi di GitHub Integrasi Aksi.