Tutorial

Angular와 Capacitor로 모바일 앱 구축하기

Angular, Capacitor 및 Konsta UI를 활용하여 네이티브 UI를 향상시키고 모바일 앱을 만드는 방법을 알아보세요.

Martin Donadieu

Martin Donadieu

콘텐츠 마케터

Angular와 Capacitor로 모바일 앱 구축하기

이 튜토리얼에서는 새로운 Angular 앱으로 시작하여 Capacitor를 사용해 네이티브 모바일 앱으로 전환하는 방법을 알아보겠습니다. 선택적으로 Konsta UI를 추가하여 Tailwind CSS로 모바일 UI를 개선할 수도 있습니다.

Capacitor를 사용하면 React Native와 같은 새로운 기술을 배우거나 큰 수정 없이도 Angular 웹 애플리케이션을 네이티브 모바일 앱으로 쉽게 변환할 수 있습니다.

몇 가지 간단한 단계만으로 대부분의 Angular 애플리케이션을 모바일 앱으로 변환할 수 있습니다.

이 튜토리얼에서는 새로운 Angular 앱으로 시작하여 Capacitor를 통해 네이티브 모바일 앱으로 전환하는 과정을 안내합니다. 추가로 Konsta UI를 사용하여 Tailwind CSS로 모바일 UI를 개선할 수도 있습니다.

Capacitor 소개

CapacitorJS는 게임 체인저입니다! 어떤 웹 프로젝트에도 쉽게 통합할 수 있으며, 애플리케이션을 네이티브 웹뷰로 래핑하여 Xcode와 Android Studio 프로젝트를 자동으로 생성합니다. 또한 플러그인을 통해 JS 브리지를 통해 카메라와 같은 네이티브 기기 기능에 접근할 수 있습니다.

Capacitor를 사용하면 복잡한 설정이나 가파른 학습 곡선 없이도 훌륭한 네이티브 모바일 앱을 얻을 수 있습니다. 간단한 API와 간소화된 기능으로 프로젝트에 쉽게 통합할 수 있습니다. Capacitor로 완전한 기능을 갖춘 네이티브 앱을 만드는 것이 얼마나 쉬운지 놀라실 것입니다!

Angular 앱 준비하기

새로운 Angular 앱을 만들기 위해 다음 명령어를 실행하세요:

Terminal window
ng new my-app
cd my-app

Angular 버전을 선택하라는 메시지가 표시되면 “Angular”를 선택하세요.

네이티브 모바일 앱을 만들기 위해서는 프로젝트를 내보내기해야 합니다. 따라서 Angular 프로젝트를 빌드하고 복사하는데 사용할 수 있는 간단한 스크립트를 package.json에 추가해 보겠습니다:

{
"scripts": {
// ...
"build": "ng build --prod"
}
}

build 명령어를 실행한 후에는 프로젝트 루트에 새로운 dist 폴더가 생성되어 있어야 합니다.

이 폴더는 나중에 Capacitor에서 사용되지만, 지금은 올바르게 설정해야 합니다.

Angular 앱에 Capacitor 추가하기

웹 앱을 네이티브 모바일 컨테이너로 패키징하기 위해서는 몇 가지 초기 단계를 따라야 하지만, 그 후에는 단순히 sync 명령어를 실행하는 것만으로 충분합니다.

먼저 Capacitor CLI를 개발 의존성으로 설치하고 프로젝트에 설정합니다. 설정 중에 이름과 번들 ID에 대해 기본값을 사용하려면 “enter”를 누르면 됩니다.

그 다음, 코어 패키지와 iOS 및 Android 플랫폼용 관련 패키지를 설치해야 합니다.

마지막으로 플랫폼을 추가하면 Capacitor가 프로젝트 루트에 각 플랫폼용 폴더를 생성합니다:

Terminal window
# Install the Capacitor CLI locally
npm install -D @capacitor/cli
# Initialize Capacitor in your Angular project
npx cap init
# Install the required packages
npm install @capacitor/core @capacitor/ios @capacitor/android
# Add the native platforms
npx cap add ios
npx cap add android

이제 Angular 프로젝트에 새로운 iosandroid 폴더가 생성된 것을 확인할 수 있어야 합니다.

이것들은 실제 네이티브 프로젝트입니다!

나중에 Android 프로젝트에 접근하려면 Android Studio를 설치해야 합니다. iOS의 경우 Mac이 필요하며 Xcode를 설치해야 합니다.

또한 프로젝트에서 capacitor.config.ts 파일을 찾을 수 있어야 합니다. 이 파일에는 동기화 중에 사용되는 기본적인 Capacitor 설정이 포함되어 있습니다. 주의해야 할 유일한 것은 빌드 명령어의 결과를 가리켜야 하는 webDir입니다. 현재는 정확하지 않습니다.

이를 수정하기 위해 capacitor.config.json 파일을 열고 webDir을 업데이트하세요:

{
"appId": "com.example.app",
"appName": "my-app",
"webDir": "dist"
}

다음 명령어를 실행하여 시도해볼 수 있습니다:

Terminal window
npm run build
npx cap sync

첫 번째 명령어 npm run build는 단순히 Angular 프로젝트를 빌드하고 정적 빌드를 복사하는 것이고, 두 번째 명령어 npx cap sync는 모든 웹 코드를 네이티브 플랫폼의 올바른 위치에 동기화하여 앱에서 표시될 수 있도록 합니다.

또한 동기화 명령어는 네이티브 플랫폼을 업데이트하고 플러그인을 설치할 수 있으므로, 새로운 Capacitor 플러그인을 설치할 때는 다시 npx cap sync를 실행해야 합니다.

모르는 사이에 이제 모든 준비가 완료되었으니, 기기에서 앱을 실행해 보겠습니다!

네이티브 앱 빌드 및 배포

iOS 앱을 개발하려면 Xcode가 설치되어 있어야 하고, Android 앱의 경우 Android Studio가 설치되어 있어야 합니다. 또한 앱 스토어에 앱을 배포하려면 iOS의 경우 Apple Developer Program에, Android의 경우 Google Play Console에 등록해야 합니다.

네이티브 모바일 개발이 처음이라면 Capacitor CLI를 사용하여 두 네이티브 프로젝트를 쉽게 열 수 있습니다:

Terminal window
npx cap open ios
npx cap open android

네이티브 프로젝트를 설정한 후에는 연결된 기기에 앱을 쉽게 배포할 수 있습니다. Android Studio에서는 모든 것이 준비될 때까지 기다린 다음, 설정을 변경하지 않고도 연결된 기기에 앱을 배포할 수 있습니다. 예시:

android-studio-run

Xcode에서는 시뮬레이터가 아닌 실제 기기에 앱을 배포하려면 서명 계정을 설정해야 합니다. 처음 하는 경우 Xcode가 과정을 안내합니다(단, Developer Program에 등록되어 있어야 합니다). 그 후에는 상단에서 연결된 기기를 선택하고 실행 버튼을 누르기만 하면 됩니다. 예시:

xcode-run

축하합니다! Angular 웹 앱을 모바일 기기에 성공적으로 배포했습니다. 예시:

angular-mobile-app

하지만 잠깐, 개발 중에 더 빠른 방법이 있습니다…

Capacitor 실시간 리로드

이제 모든 최신 프레임워크에서 핫 리로드 기능을 사용하는 데 익숙해졌을 것입니다. 좋은 소식은 최소한의 노력으로 모바일 기기에서도 동일한 기능을 사용할 수 있다는 것입니다!

Capacitor 앱이 특정 URL에서 콘텐츠를 로드하도록 하여 네트워크에서 실시간 리로드로 로컬에서 호스팅되는 애플리케이션에 접근할 수 있습니다.

첫 번째 단계는 로컬 IP 주소를 확인하는 것입니다. Mac을 사용하는 경우 터미널에서 다음 명령어를 실행하여 확인할 수 있습니다:

Terminal window
ipconfig getifaddr en0

Windows에서는 다음을 실행하세요:

Terminal window
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:4200',
cleartext: true
}
};
export default config;

이 예제에서는 기본 Angular 포트를 사용했지만, 올바른 IP와 포트를 사용해야 합니다.

이제 이러한 변경 사항을 네이티브 프로젝트에 복사하여 적용할 수 있습니다:

Terminal window
npx cap copy

copy 명령어는 sync와 비슷하지만 네이티브 프로젝트를 업데이트하지 않고 웹 폴더와 구성에 대한 변경 사항만 복사합니다.

이제 Android Studio나 Xcode를 통해 앱을 한 번 더 배포할 수 있습니다. 그 후에 Angular 앱에서 무언가를 변경하면 앱이 자동으로 리로드되어 변경 사항이 표시됩니다!

주의하세요 카메라와 같은 새로운 플러그인을 설치하는 경우에는 여전히 네이티브 프로젝트를 다시 빌드해야 합니다. 이는 네이티브 파일이 변경되었기 때문에 즉시 적용할 수 없습니다.

구성에서 올바른 IP와 포트를 사용해야 합니다. 위의 코드 블록은 예시를 위해 기본 Angular 포트를 보여줍니다.

Capacitor 플러그인 사용하기

이제 앞서 여러 번 언급했던 Capacitor 플러그인을 실제로 사용해보겠습니다. 다음 명령어를 실행하여 비교적 간단한 플러그인을 설치할 수 있습니다:

Terminal window
npm i @capacitor/share

Share 플러그인은 특별한 것은 없지만 네이티브 공유 대화상자를 표시합니다! 이제 패키지를 가져오고 앱에서 해당 share() 함수를 호출하기만 하면 됩니다. src/app/app.component.ts를 다음과 같이 변경해보겠습니다:

import { Component } from '@angular/core';
import { Share } from '@capacitor/share';
@Component({
selector: 'app-root',
templateUrl: './app.component.html',
styleUrls: ['./app.component.scss']
})
export class AppComponent {
title = 'my-app';
async share() {
await Share.share({
title: 'Open Youtube',
text: 'Check new video on youtube',
url: 'https://www.youtube.com',
dialogTitle: 'Share with friends'
});
}
}

앞서 언급했듯이 새로운 플러그인을 설치할 때는 동기화 작업을 수행하고 앱을 기기에 다시 배포해야 합니다. 이를 위해 다음 명령어를 실행하세요:

npx cap sync

버튼을 누르면 아름다운 네이티브 공유 대화상자가 작동하는 것을 볼 수 있습니다!

Konsta UI 추가하기

Nuxt 3 앱에서 Konsta UI를 사용하려면 tailwind가 이미 설치되어 있어야 하며 패키지를 설치해야 합니다:

Terminal window
npm i konsta

추가로 tailwind.config.js 파일을 수정해야 합니다:

// import konstaConfig config
const konstaConfig = require('konsta/config')
// wrap config with konstaConfig config
module.exports = konstaConfig({
content: [
'./src/**/*.{html,ts}',
],
darkMode: 'media', // or 'class'
theme: {
extend: {},
},
variants: {
extend: {},
},
plugins: [],
})

konstaConfig는 기본(또는 사용자 지정) Tailwind CSS 구성을 Konsta UI에 필요한 추가 변형과 유틸리티로 확장합니다.

이제 전역 매개변수(theme와 같은)를 설정할 수 있도록 메인 App 컴포

CapacitorJS 앱을 위한 즉시 업데이트

앱 스토어의 지연 없이 CapacitorJS 앱에 즉시 업데이트, 수정 사항 및 기능을 푸시하세요. Capgo를 사용하여 원활한 통합, 종단 간 암호화 및 실시간 업데이트를 경험해 보세요.

지금 시작하세요

최신 뉴스

Capgo는 진정으로 전문적인 모바일 앱을 만드는 데 필요한 최고의 인사이트를 제공합니다.

Capacitor 앱의 양방향 통신
Development,Mobile,Updates
April 26, 2025

Capacitor 앱의 양방향 통신