이 튜토리얼에서는 새로운 Nuxt 3 앱으로 시작하여 Capacitor를 사용해 네이티브 영역으로 이동하고, 최종적으로는 향상된 Tailwind CSS 모바일 UI를 위해 Konsta UI를 추가할 것입니다. 단, 마지막 단계는 완전히 선택사항입니다.
Capacitor를 사용하면 React Native와 같은 새로운 기술을 배우거나 큰 수정 없이도 Nuxt 3 웹 애플리케이션을 네이티브 모바일 앱으로 쉽게 변환할 수 있습니다.
몇 가지 간단한 단계만으로 대부분의 Nuxt 3 애플리케이션을 모바일 앱으로 변환할 수 있습니다.
이 튜토리얼은 새로운 Nuxt 3 앱으로 시작하여 Capacitor를 통해 네이티브 모바일 앱으로 전환하는 과정을 안내합니다. 추가로 선택적으로 Konsta UI를 사용하여 Tailwind CSS로 모바일 UI를 개선할 수 있습니다.
Capacitor 소개
CapacitorJS는 정말 혁신적입니다! 어떤 웹 프로젝트에도 쉽게 통합할 수 있으며, 애플리케이션을 네이티브 웹뷰로 래핑하고 Xcode와 Android Studio 프로젝트를 자동으로 생성합니다. 또한 플러그인을 통해 JS 브리지를 통한 카메라와 같은 네이티브 기기 기능에 접근할 수 있습니다.
Capacitor를 사용하면 복잡한 설정이나 가파른 학습 곡선 없이도 훌륭한 네이티브 모바일 앱을 얻을 수 있습니다. 간단한 API와 간소화된 기능으로 프로젝트에 쉽게 통합할 수 있습니다. Capacitor로 완전한 기능을 갖춘 네이티브 앱을 얼마나 쉽게 만들 수 있는지 놀라실 것입니다!
Nuxt 3 앱 준비하기
새로운 Nuxt 3 앱을 만들려면 다음 명령어를 실행하세요:
npx nuxi init my-appcd my-appnpm install
Nuxt 버전을 선택하라는 메시지가 나타나면 “Nuxt 3”을 선택하세요.
네이티브 모바일 앱을 만들기 위해서는 프로젝트의 내보내기가 필요합니다. 따라서 Nuxt 프로젝트를 빌드하고 복사하는데 사용할 수 있는 간단한 스크립트를 package.json에 포함시켜 보겠습니다:
{ "scripts": { // ... "generate": "nuxt generate" }}
generate
명령을 실행한 후에는 프로젝트 루트에 새로운 dist
폴더가 생성된 것을 확인할 수 있습니다.
이 폴더는 나중에 Capacitor에서 사용될 것이지만, 지금은 올바르게 설정해야 합니다.
Nuxt 3 앱에 Capacitor 추가하기
네이티브 모바일 컨테이너에 웹 앱을 패키징하기 위해서는 몇 가지 초기 단계를 따라야 하지만, 이후에는 단순히 sync
명령어를 실행하는 것만으로 충분합니다.
먼저 개발 의존성으로 Capacitor CLI를 설치하고 프로젝트 내에서 설정할 수 있습니다. 설정 중에 이름과 번들 ID에 대해 기본값을 수락하려면 “enter”를 누르면 됩니다.
그 다음, 코어 패키지와 iOS 및 Android 플랫폼용 관련 패키지를 설치해야 합니다.
마지막으로 플랫폼을 추가하면 Capacitor가 프로젝트 루트에 각 플랫폼용 폴더를 생성합니다:
# Install the Capacitor CLI locallynpm install -D @capacitor/cli
# Initialize Capacitor in your Nuxt projectnpx cap init
# Install the required packagesnpm install @capacitor/core @capacitor/ios @capacitor/android
# Add the native platformsnpx cap add iosnpx cap add android
이 시점에서 Nuxt 3 프로젝트에 새로운 ios와 android 폴더가 생성된 것을 확인할 수 있습니다.
이것들은 실제 네이티브 프로젝트입니다!
나중에 Android 프로젝트에 접근하려면 Android Studio를 설치해야 합니다. iOS의 경우 Mac이 필요하며 Xcode를 설치해야 합니다.
또한 프로젝트에서 capacitor.config.ts 파일을 찾을 수 있는데, 이는 동기화 중에 사용되는 기본적인 Capacitor 설정을 포함하고 있습니다. 주의해야 할 유일한 것은 빌드 명령의 결과를 가리켜야 하는 webDir입니다. 현재는 정확하지 않습니다.
이를 수정하기 위해 capacitor.config.json 파일을 열고 webDir을 업데이트하세요:
{ "appId": "com.example.app", "appName": "my-app", "webDir": "dist"}
다음 명령어를 실행하여 시도해볼 수 있습니다:
npm run generatenpx cap sync
첫 번째 명령어 npm run generate
는 단순히 Nuxt 3 프로젝트를 빌드하고 정적 빌드를 복사하며, 두 번째 명령어 npx cap sync
는 모든 웹 코드를 네이티브 플랫폼의 올바른 위치에 동기화하여 앱에서 표시될 수 있도록 합니다.
또한 동기화 명령은 네이티브 플랫폼을 업데이트하고 플러그인을 설치할 수 있으므로, 새로운 Capacitor 플러그인을 설치할 때는 다시 npx cap sync
를 실행해야 할 때입니다.
모르는 사이에 이제 실제로 완료되었으니, 기기에서 앱을 확인해보겠습니다!
네이티브 앱 빌드 및 배포
iOS 앱을 개발하려면 Xcode가 설치되어 있어야 하고, Android 앱의 경우 Android Studio가 설치되어 있어야 합니다. 또한 앱스토어에 앱을 배포하려면 iOS의 경우 Apple Developer Program에, Android의 경우 Google Play Console에 등록해야 합니다.
네이티브 모바일 개발이 처음이라면 Capacitor CLI를 사용하여 두 네이티브 프로젝트를 쉽게 열 수 있습니다:
npx cap open iosnpx cap open android
네이티브 프로젝트를 설정한 후에는 연결된 기기에 앱을 배포하는 것이 쉽습니다. Android Studio에서는 모든 것이 준비될 때까지 기다린 다음, 설정을 변경하지 않고도 연결된 기기에 앱을 배포할 수 있습니다. 예시:
Xcode에서는 시뮬레이터가 아닌 실제 기기에 앱을 배포하기 위해 서명 계정을 설정해야 합니다. 처음 하는 경우 Xcode가 과정을 안내합니다 (단, Developer Program에 등록되어 있어야 합니다). 그 후에는 상단에서 연결된 기기를 선택하고 실행 버튼을 누르기만 하면 됩니다. 예시:
축하합니다! Nuxt 3 웹 앱을 모바일 기기에 성공적으로 배포했습니다. 예시:

하지만 개발 중에 더 빠른 방법도 있습니다…
Capacitor 라이브 리로드
이제 모든 최신 프레임워크에서 핫 리로드를 사용하는 데 익숙해졌을 것입니다. 좋은 소식은 최소한의 노력으로 모바일 기기에서도 같은 기능을 사용할 수 있다는 것입니다!
특정 URL에서 Capacitor 앱이 콘텐츠를 로드하도록 하여 라이브 리로드가 가능한 로컬 호스팅 애플리케이션에 네트워크상에서 접근할 수 있게 합니다.
첫 번째 단계는 로컬 IP 주소를 확인하는 것입니다. Mac을 사용하는 경우 터미널에서 다음 명령어를 실행하여 확인할 수 있습니다:
ipconfig getifaddr en0
Windows에서는 다음을 실행합니다:
ipconfig
그런 다음 IPv4 주소를 찾으세요.
capacitor.config.ts
파일에 다른 항목을 추가하여 서버에서 직접 앱을 로드하도록 Capacitor에 지시할 수 있습니다:
import { CapacitorConfig } from '@capacitor/cli';
const config: CapacitorConfig = { appId: 'com.example.app', appName: 'my-app', webDir: 'dist', bundledWebRuntime: false, server: { url: 'http://192.168.x.xx:3000', cleartext: true }};
export default config;
이 예시에서는 Nuxt 3의 기본 포트를 사용했지만, 올바른 IP와 포트를 사용해야 합니다.
이제 이러한 변경사항을 네이티브 프로젝트에 복사하여 적용할 수 있습니다:
npx cap copy
copy
명령은 sync
와 비슷하지만, 네이티브 프로젝트를 업데이트하지 않고 웹 폴더와 구성에 대한 변경사항만 복사합니다.
이제 Android Studio나 Xcode를 통해 앱을 한 번 더 배포할 수 있습니다. 그 후에 Nuxt 앱에서 무언가를 변경하면, 앱이 자동으로 리로드되어 변경사항을 보여줍니다!
주의하세요 카메라와 같은 새로운 플러그인을 설치하는 경우에는 여전히 네이티브 프로젝트의 재빌드가 필요합니다. 이는 네이티브 파일이 변경되기 때문에 실시간으로 수행할 수 없습니다.
구성에서 올바른 IP와 포트를 사용해야 합니다. 위의 코드 블록은 예시를 위해 Nuxt 3의 기본 포트를 보여줍니다.
Capacitor 플러그인 사용하기
이전에 여러 번 언급했던 Capacitor 플러그인을 실제로 사용해보겠습니다. 다음 명령어를 실행하여 비교적 간단한 플러그인을 설치할 수 있습니다:
npm i @capacitor/share
Share 플러그인은 특별한 것은 없지만, 네이티브 공유 대화상자를 표시합니다! 이를 위해 이제 패키지를 가져오고 앱에서 해당 share()
함수를 호출하기만 하면 됩니다. pages/index.vue를 다음과 같이 변경해보겠습니다:
<template> <div> <h1>Welcome to Nuxt 3 and Capacitor!</h1> <button @click="share">Share now!</button> </div></template>
<script setup lang="ts">import { Share } from '@capacitor/share';
async function share() { await Share.share({ title: 'Open Youtube', text: 'Check new video on youtube', url: 'https://www.youtube.com', dialogTitle: 'Share with friends' });}</script>
앞서 언급했듯이, 새로운 플러그인을 설치할 때는 동기화 작업을 수행하고 앱을 기기에 다시 배포해야 합니다. 이를 위해 다음 명령어를 실행하세요:
npx cap sync
버튼을 누르면 아름다운 네이티브 공유 대화상자가 작동하는 것을 볼 수 있습니다!
Konsta UI 추가하기
Nuxt 3 앱에서 Konsta UI를 사용하려면 tailwind가 이미 설치되어 있어야 하며 패키지를 설치해야 합니다:
npm i konsta
또한 tailwind.config.js
파일을 수정해야 합니다:
// import konstaConfig configconst konstaConfig = require('konsta/config')
// wrap config with konstaConfig configmodule.exports = konstaConfig({ content: [ './pages/**/*.{vue}', './components/**/*.{vue}', ], darkMode: 'media', // or 'class' theme: { extend: {}, }, variants: { extend: {}, }, plugins: [],})
konstaConfig
는 Konsta UI에 필요한 추가 변형과 헬퍼 유틸리티를 포함하여 기본(또는