소개
Next.js로 모바일 앱을 처음부터 만들고 싶으십니까? 이 가이드는 모바일 개발을 처음부터 시작하는 Next.js 15 프로젝트를 만들고, __CAPGO_KEEP_0__ 8을 사용하여 iOS 및 Android 앱으로 패키징하는 방법을 안내합니다. Capacitor 8.
이 튜토리얼을 마치면 시뮬레이터에서 작동하는 모바일 앱을 만들 수 있으며, 개발을 계속하고 나중에는 앱 스토어와 구글 플레이 스토어에 게시할 수 있습니다.
시간 소요: ~30분
만들어 볼 건대:
- Next.js 15 프로젝트에 App Router를 사용하는 새로운 프로젝트
- 모바일용 정적 내보내기 설정
- Capacitor 8에 필수 플러그인을 포함한
- 자연어 iOS 및 Android 앱
- 라이브 리로드 개발 설정
Next.js 앱이 이미 있으신가요? Next.js 앱을 모바일로 변환하는 방법 대신.
사전 요구 사항
__CAPGO_KEEP_0__를 설치했는지 확인하세요:
- Node.js 18 이상이 설치되어야 합니다. (설치 여부를 확인하세요
node --version) - Bun 패키지 매니저 (
curl -fsSL https://bun.sh/install | bash) - Xcode (macOS에서만 iOS 개발을 위해)
- Android Studio (Android 개발을 위해)
1단계: 새로운 Next.js 프로젝트 만들기
새로운 Next.js 15 프로젝트를 생성하세요:
bunx create-next-app@latest my-mobile-app
프로세스 진행 중에 다음 옵션을 선택하세요:
- TypeScript: Yes (recommended)
- ESLint: Yes
- Tailwind CSS: Yes (recommended for mobile styling)
src/폴더: Yes- App Router: Yes (recommended)
- Import alias: 기본값 (
@/*)
프로젝트로 이동하세요:
cd my-mobile-app
2단계: Next.js를 정적 내보내기 위해 구성하세요.
Capacitor은 정적 HTML/JS/CSS 파일이 필요합니다. Next.js를 정적 내보내기 위해 구성하려면 next.config.ts:
import type { NextConfig } from 'next';
const nextConfig: NextConfig = {
output: 'export',
images: {
unoptimized: true,
},
// Ensure trailing slashes for proper routing in Capacitor
trailingSlash: true,
};
export default nextConfig;
이러한 설정은 왜 필요한가요?
output: 'export'— 정적 HTML을 생성하여 Node.js 서버가 필요하지 않도록 합니다.images: { unoptimized: true }— Next.js Image Optimization을 비활성화합니다 (서버가 필요합니다).trailingSlash: true— 네이티브 WebView에서 올바른 라우팅을 보장합니다.
3단계: 모바일 스크립트 추가
모바일 개발 스크립트를 업데이트: package.json 빌드를 테스트하세요:
{
"scripts": {
"dev": "next dev",
"build": "next build",
"start": "next start",
"lint": "next lint",
"mobile": "bun run build && bunx cap sync",
"mobile:ios": "bun run mobile && bunx cap open ios",
"mobile:android": "bun run mobile && bunx cap open android"
}
}
빌드 결과를 확인해야 합니다.
bun run build
Navigate to your project: is not translated as it is a protected token out __CAPGO_KEEP_0__ 폴더에 정적 파일이 있습니다.
4단계: Capacitor 8을 설치하세요.
Capacitor의 핵심 패키지를 설치하세요:
bun add @capacitor/core
bun add -D @capacitor/cli
대부분의 모바일 앱이 필요로 하는 필수 플러그인을 설치하세요:
bun add @capacitor/app @capacitor/keyboard @capacitor/splash-screen @capacitor/status-bar @capacitor/preferences
이 플러그인이 하는 일은?
- @capacitor/앱 — 앱의 생명주기 이벤트 (전경/후경, 깊이 링크)
- @capacitor/키보드 — 키보드 동작을 제어하세요.
- @capacitor/스플래시 스크린 — 네이티브 스크린을 제어하세요.
- @capacitor/상태바 — 장치 상태 바 스타일링
- @capacitor/설정 — 키-값 저장소 (localStorage와 같은 네이티브 저장소)
5단계: Capacitor 초기화
Capacitor을 프로젝트 세부 정보와 초기화하세요:
bunx cap init "My Mobile App" com.example.mymobileapp --web-dir out
대체:
"My Mobile App"앱의 표시 이름과 함께com.example.mymobileapp역 도메인 표기법의 앱 ID와 함께
이것은 capacitor.config.ts. 플러그인 구성으로 업데이트하세요:
import type { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = {
appId: 'com.example.mymobileapp',
appName: 'My Mobile App',
webDir: 'out',
plugins: {
SplashScreen: {
launchShowDuration: 2000,
launchAutoHide: true,
androidScaleType: 'CENTER_CROP',
splashFullScreen: true,
splashImmersive: true,
},
Keyboard: {
resize: 'body',
resizeOnFullScreen: true,
},
StatusBar: {
style: 'light',
},
},
};
export default config;
6단계: 네이티브 플랫폼 추가
플랫폼 패키지를 설치하세요:
bun add @capacitor/ios @capacitor/android
자연적인 프로젝트 생성:
bunx cap add ios
bunx cap add android
이것은 ios 및 android 자연적인 프로젝트가 포함된 디렉토리를 생성합니다.
7단계: 빌드 및 실행
프로젝트를 빌드하고 네이티브 플랫폼과 동기화하세요:
bun run mobile
iOS 시뮬레이터에서 열기:
bun run mobile:ios
또는 Android 에뮬레이터에서 열기:
bun run mobile:android
Xcode (iOS)에서:
- 디바이스 드롭다운에서 시뮬레이터를 선택하세요
- Play 버튼을 클릭하거나
Cmd + R
Android Studio에서:
- Gradle 동기화가 완료될 때까지 기다려 주세요.
- 디바이스 드롭다운에서 에뮬레이터를 선택하세요.
- Run 버튼을 클릭하거나
Shift + F10
8 단계: 라이브 리로드 설정
빠른 개발을 위해 라이브 리로드를 활성화하여 변경 사항이 즉시 디바이스에 나타나도록 하세요.
- 디바이스 IP 주소를 찾으세요:
# macOS
ipconfig getifaddr en0
# Windows
ipconfig
- 개발 Capacitor 설정을 생성하세요. 다음을 추가하세요:
capacitor.config.ts:
import type { CapacitorConfig } from '@capacitor/cli';
const devConfig: CapacitorConfig = {
appId: 'com.example.mymobileapp',
appName: 'My Mobile App',
webDir: 'out',
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: 'out',
plugins: {
// ... same plugin config
},
};
const config = process.env.NODE_ENV === 'development' ? devConfig : prodConfig;
export default config;
- 개발 서버를 시작하고 설정을 네이티브로 복사하세요:
bun run dev &
NODE_ENV=development bunx cap copy
- Xcode/Android Studio에서 다시 빌드하세요.
현재 Next.js code의 편집 사항은 디바이스에서 즉시 리로드됩니다.
9 단계: 첫 번째 모바일 화면 만들기
간단한 모바일 친화적인 홈 화면을 만들겠습니다. 업데이트 src/app/page.tsx:
'use client';
import { useEffect, useState } from 'react';
import { App } from '@capacitor/app';
import { Keyboard } from '@capacitor/keyboard';
export default function Home() {
const [appInfo, setAppInfo] = useState<{ name: string; version: string } | null>(null);
useEffect(() => {
// Get app info on mount
App.getInfo().then(setAppInfo).catch(console.error);
// Handle back button on Android
const backHandler = App.addListener('backButton', ({ canGoBack }) => {
if (!canGoBack) {
App.exitApp();
} else {
window.history.back();
}
});
// Hide keyboard when tapping outside inputs
const keyboardHandler = Keyboard.addListener('keyboardWillShow', () => {
document.body.classList.add('keyboard-open');
});
return () => {
backHandler.then(h => h.remove());
keyboardHandler.then(h => h.remove());
};
}, []);
return (
<main className="min-h-screen bg-linear-to-b from-blue-500 to-blue-700 flex flex-col items-center justify-center p-6 text-white">
<h1 className="text-4xl font-bold mb-4">My Mobile App</h1>
<p className="text-xl mb-8 text-center opacity-90">
Built with Next.js 15 + Capacitor 8
</p>
{appInfo && (
<div className="bg-white/20 rounded-lg p-4 backdrop-blur-sm">
<p className="text-sm">
{appInfo.name} v{appInfo.version}
</p>
</div>
)}
<div className="mt-12 space-y-4 w-full max-w-sm">
<button className="w-full py-4 px-6 bg-white text-blue-600 rounded-xl font-semibold text-lg shadow-lg active:scale-95 transition-transform">
Get Started
</button>
<button className="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">
Learn More
</button>
</div>
</main>
);
}
10단계: 안전 영역 처리 추가
모바일 기기는 notch, 홈 인디케이터, 상태 바를 가지고 있습니다. Tailwind를 사용하여 안전 영역 처리를 추가하세요.
수정 src/app/globals.css:
@tailwind base;
@tailwind components;
@tailwind utilities;
: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;
}
/* Keyboard handling */
.keyboard-open {
--sab: 0px;
}
프로젝트 구조
프로젝트는 다음과 같이 보이게 되어야 합니다.
my-mobile-app/
├── android/ # Android native project
├── ios/ # iOS native project
├── out/ # Static build output
├── src/
│ ├── app/
│ │ ├── globals.css
│ │ ├── layout.tsx
│ │ └── page.tsx
│ └── ...
├── capacitor.config.ts # Capacitor configuration
├── next.config.ts # Next.js configuration
├── package.json
└── ...
다음 단계
이제 Next.js 모바일 앱이 작동하고 있습니다. 다음 단계를 수행하세요:
필수 설정
- 앱 아이콘: 기본 아이콘을
ios/App/App/Assets.xcassets스플래시 화면:android/app/src/main/res - Splash Screen: 자연스러운 프로젝트에서 커스터마이즈하거나 사용
@capacitor/splash-screen__CAPGO_KEEP_0__ - 깊이 있는 링크: __CAPGO_KEEP_0__
앱에 대한 URL 스키마를 구성
- 더 많은 기능 추가
bun add @capacitor/camera - 카메라:
bun add @capacitor/geolocation - 위치 정보:
bun add @capacitor/push-notifications - 푸시 알림:
bun add @capacitor/filesystem
파일 시스템:
UI 향상 Konsta UI iOS/Android 컴포넌트를 위한 원생 iOS/Android UI:
bun add konsta
OTA 업데이트
설정 Capgo 앱스토어 재제출 없이 업데이트를 푸시하세요:
bunx @capgo/cli init
문제 해결
빌드가 “모듈을 찾을 수 없습니다”로 실패합니다.
실행 bun install 다시 시도해 보세요.
iOS: “인증서를 찾을 수 없습니다” Xcode를 열고 Signing & Capabilities로 이동하여 개발 팀을 선택하세요.
Android: “SDK 위치를 찾을 수 없습니다”
생성 android/local.properties 으로 sdk.dir=/path/to/android/sdk
장치에 나타나지 않는 변경 사항
변경 사항이 나타나지 않으면 장치에 변경 사항이 적용되었는지 확인하세요. 라이브 리로드를 위해 IP 주소가 정확하고 개발 서버가 실행 중인지 확인하세요. bun run mobile 자원
__CAPGO_KEEP_0__ 8 문서
- Capacitor 8 Documentation
- __CAPGO_KEEP_0__ - 실시간 업데이트
- Capgo - Live Updates
- 앱을 배포할 준비가 되셨나요? __CAPGO_KEEP_0__이 업데이트를 더 빠르게 전달하는 데 어떻게 도움이 될 수 있는지 알아보세요 —
Ready to ship your app? Learn how Capgo can help you deliver updates faster — __CAPGO_KEEP_0__ 오늘.