DEV Community

Cover image for How to create Android and iOS apps from the NuxtJS application using CapacitorJS
Yevhen Bondar for Daiquiri Team

Posted on • Updated on

How to create Android and iOS apps from the NuxtJS application using CapacitorJS

In this guide, I will show how to wrap an existing NuxtJS web application into Android and iOS mobile apps using CapacitorJS

Capacitor is an open-source native runtime for building Web Native apps. Create cross-platform iOS, Android, and Progressive Web Apps with JavaScript, HTML, and CSS.

CapacitorJS runs your static site on a local browser and shows it to the user. Also, it has some interface between native and web contexts for accessing native features.

But why do you need this if users can access your website from mobile browsers?

  1. It's more useful for users. If a user uses your web app frequently, it's easier for them just to click on your app icon than go to the browser and search for your app bookmark or type your app domain name. Both Android and iOS have the feature "Add website to home screen". But a separate native app provides better UX.
  2. Distribution channel. Users can search for your app in AppStore and PlayMarket. So, it's better to be present on all popular platforms to reach more users.
  3. Native features. Maybe, your web app doesn't need them. But after you create a mobile version of your app, you can change your mind. At least you can add notifications by FCM.

I think we are done with the "why?" part. Let's go to the "how?" part.

Creating dummy NuxtJS application

To simplify this guide, I'll create a new Nuxt application. Feel free to jump to the Installing CapacitorJS section if you already have one.

So, let's create a nuxt3 application using the official guide. I'll use NodeJS v16 and Yarn v1.22 for installation.

Open a terminal and run:

$ yarn add global nuxi
$ yarn nuxi init nuxt-mobile
$ cd nuxt-mobile
$ yarn install
Enter fullscreen mode Exit fullscreen mode

Here we installed nuxi Nuxt Command Line Interface, created a new project nuxt-mobile, and installed dependencies from package.json. You can replace nuxt-mobile with any name.

Next, let's change app.vue. Replace the existing file with the following one:

<template>
  <div>
    <h1>Nuxt Mobile</h1>

    <p>This is a basic example of a mobile app built with NuxtJS and CapacitorJS</p>
  </div>
</template>
Enter fullscreen mode Exit fullscreen mode

Now, let's see what we got. Run the development server:

$ yarn dev -o
Enter fullscreen mode Exit fullscreen mode

You will be navigated to the browser. Here you will see your web application.

a NuxtJS application in a browser

It's pretty empty, but it will be enough to show how to wrap a web application into mobile apps.

Installing CapacitorJS

Now, let's add CapacitorJS to the application. I'll follow instructions from the official guide:

In the root of your app, install Capacitor's main npm depdencies: the core JavaScript runtime and the command line interface (CLI).

$ yarn add @capacitor/core
$ yarn add --dev @capacitor/cli
Enter fullscreen mode Exit fullscreen mode

Then, initialize Capacitor using the CLI questionnaire:

$ yarn cap init
Enter fullscreen mode Exit fullscreen mode

The CLI will ask you questions about your package. You can pick any Name and Package (I used NuxtMobile and com.mycompany.nuxtmobile values). Then you need to set the Web asset directory as dist. This is a destination on NuxtJS static site. The CLI will save these answers into capacitor.config.json and check the file content.

After the Capacitor core runtime is installed, you can install the Android and iOS platforms.

$ yarn add @capacitor/android @capacitor/ios
Enter fullscreen mode Exit fullscreen mode

CapacitorJS uses a static version of the site. So, we need to generate it:

$ yarn generate 
Enter fullscreen mode Exit fullscreen mode

Now we have a static site so that we can initialize iOS and Android applications:

$ yarn cap add android
$ yarn cap add ios
Enter fullscreen mode Exit fullscreen mode

These commands create native applications in android and ios folders. They clone web content from the dist directory to ios/App/App/public and android/app/src/main/assets/public directories.

Every time you change your site, you need to run yarn generate to generate a new static site and npx cap sync to update the native apps.

Running Android app

Let's run the Android application. First, download and install AndroidStudio.

After you finish, return to the console and run yarn cap open android. This will open android folder in AndroidStudio. Here you can change your Android files and run the application.

Let's add an emulator to run. Go to the "Tools" -> "Device Manager" and click "Create Device."

First, you need to pick "Hardware device." The main difference between different devices is a screen size and availability of PlayMarket. I'll pick the Pixel 2 because it has PlayMarket and a 5.0" screen size.

Choosing the Android device for the emulator

Then, you need to choose the Android OS image. I will use Android API 33.

Choosing Android API for the emulator

Finally, click 'Next' and 'Finish'. After this, you will see a new device on the 'Devices' dropdown.

Now, you can choose your device and click 'Run' to build and start the application:

Running an Android application

Android Studio will start the emulator, build, install and run your application:

A capacitor application runs on the Android emulator

We are done with Android; let's move to the iOS part.

Running iOS app

To build the application for iOS, you need a MacBook. If you have Linux or Windows, you can skip this part.

First, you need XCode to build and run the iOS application. You can get it on AppStore.

After installation, return to the console and run yarn cap open ios. This command will open the ios folder as an XCode project. Here you can change iOS application files and settings; build and run the application.

Now, we need to pick an emulator device to run the application. I'll use the iPod touch.

Then click 'Run'. XCode will build the app and run it on the device.

XCode, running a project

A capacitor application runs on the iOS emulator

We are done with the iOS part.

The end

Congratulations! In this guide, we turn a new NuxtJS web application into iOS and Android mobile applications. It's a very basic web app so we wouldn't upload it to stores :) But if you already have a full-featured web application, you can turn it into mobile apps and upload them to PlayMarket and AppStore!

You can find the source code of the project here.

If you need to build a web or mobile app prototype, check out our website or connect with me directly on LinkedIn.

Latest comments (0)