メインコンテンツにジャンプ
Tutorial

Offline Screen in Vue, Angular, React with Capacitor

Vue、Angular、またはReactアプリケーションでオフライン画面を実装する方法を学びます。Network APIとCapacitorを使用して、オフラインシナリオを効果的に処理し、ユーザー体験を向上させます。

マーティン・ドナディュー

マーティン・ドナディュー

コンテンツマーケター

Offline Screen in Vue, Angular, React with Capacitor

Vue 3、Angular 14、またはReactでオフライン画面を作成する方法

このチュートリアルでは、Vue 3、Angular 14、Reactアプリケーションでオフライン画面を作成する方法を学びます。Network APIを使用すると、ネットワークと接続性に関する情報を取得できます。Network APIを使用すると、オフラインシナリオを処理し、ユーザー体験を向上させることができます。

前提条件

チュートリアルを始める前に、以下をインストールしてください:

プロジェクトの設定

まず、各フレームワークのためのプロジェクト用のスケルトンを使用して、新しいプロジェクトを作成しましょう。

Vue 3

ターミナルを開いて、次のコマンドを実行して、新しい Vue 3 プロジェクトを作成してください。

vue create offline-screen-vue3

デフォルトのプリセットを選択し、プロジェクトの作成を待ちます。

Angular 14

ターミナルを開いて、次のコマンドを実行して、新しい Angular 14 プロジェクトを作成してください。

ng new offline-screen-angular14

プロンプトに従い、追加の機能について尋ねられたときは、スペースバーを押して「Routing」を選択してください。 プロジェクトが作成されるのを待ってください。 React

ターミナルを開いて、次のコマンドを実行して新しいReactプロジェクトを作成してください。

プロジェクトが作成されるのを待ってください。

npx create-react-app offline-screen-react

ネットワーク__CAPGO_KEEP_0__のインストール

ネットワークAPIを提供するパッケージをインストールしましょう。

ターミナルを開いてプロジェクトディレクトリに移動してください。次に、次のコマンドを実行してパッケージをインストールしてください。 @capacitor/network APIプロジェクトの場合、次のコマンドも実行してネイティブプロジェクトファイルを同期してください。

__CAPGO_KEEP_0__と__CAPGO_KEEP_1__がグローバルにインストールされていることを確認してください。

npm install @capacitor/network

For Capacitor projects, also run the following command to sync the native project files:

npx cap sync

Make sure you have the Capacitor CLI installed globally by running:

npm install -g @capacitor/cli

オフライン画面の実装

次に、各フレームワークでオフライン画面の機能を実装します。ユーザーがオフラインになったときに、シンプルなメッセージを表示します。

Vue 3

Vue 3 プロジェクトで、 src/main.js ファイルを開き、 Network モジュールをインポートします。 @capacitor/network:

import { createApp } from 'vue';
import { Network } from '@capacitor/network';

const app = createApp(App);

// Your application setup

app.mount('#app');

Network.addListener('networkStatusChange', status => {
  if (status.connected) {
    // User is back online
    // Hide the offline screen
    document.getElementById('offline-screen').style.display = 'none';
  } else {
    // User is offline
    // Display the offline screen
    document.getElementById('offline-screen').style.display = 'block';
  }
});

const logCurrentNetworkStatus = async () => {
  const status = await Network.getStatus();
  console.log('Network status:', status);
};

アプリケーションテンプレート (App.vue) に、id が <div> のエレメントを追加して、オフライン画面のメッセージを表示します。 offline-screen ユーザーがオフラインになったときに、オフライン画面が表示されます。ユーザーがオンラインに戻ったときに、オフライン画面が非表示になります。

<template>
  <div id="app">
    <div id="offline-screen">
      <h1>You are offline</h1>
      <p>Please check your internet connection and try again.</p>
    </div>
    <!-- Your application content -->
  </div>
</template>

<style>
#offline-screen {
  display: none;
  text-align: center;
  padding: 20px;
  background-color: #f2f2f2;
}

#offline-screen h1 {
  font-size: 24px;
}

#offline-screen p {
  font-size: 16px;
}
</style>

Angular 14

Angular 14

Angular 14 のプロジェクトで、ファイルを開き、 src/app/app.component.ts __CAPGO_KEEP_0__ Network モジュールをインポートする @capacitor/network:

import { Component } from '@angular/core';
import { Network } from '@capacitor/network';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {

  constructor() {
    Network.addListener('networkStatusChange', status => {
      if (status.connected) {
        // User is back online
        // Hide the offline screen
        document.getElementById('offline-screen').style.display = 'none';
      } else {
        // User is offline
        // Display the offline screen
        document.getElementById('offline-screen').style.display = 'block';
      }
    });
  }

  logCurrentNetworkStatus = async () => {
    const status = await Network.getStatus();
    console.log('Network status:', status);
  };

}

モジュールapp.component.htmlアプリケーションテンプレート ( <div> ) に、id が " offline-screen " の要素を追加して、オフライン画面メッセージを表示します。

<div id="offline-screen">
  <h1>You are offline</h1>
  <p>Please check your internet connection and try again.</p>
</div>

<!-- Your application content -->

ファイルに以下のスタイルを追加します。 app.component.css オフライン画面が表示されます。ユーザーがオンラインに戻ると、オフライン画面が非表示になります。

#offline-screen {
  display: none;
  text-align: center;
  padding: 20px;
  background-color: #f2f2f2;
}

#offline-screen h1 {
  font-size: 24px;
}

#offline-screen p {
  font-size: 16px;
}

__CAPGO_KEEP_1__

プロジェクトで、ファイルを開きます。

React src/App.js ファイルとインポートする Network __CAPGO_KEEP_0__モジュールから @capacitor/network:

import React, { useEffect } from 'react'
import { Network } from '@capacitor/network'

function App() {

  useEffect(() => {
    Network.addListener('networkStatusChange', (status) => {
      if (status.connected) {
        // User is back online
        // Hide the offline screen
        document.getElementById('offline-screen').style.display = 'none'
      }
      else {
        // User is offline
        // Display the offline screen
        document.getElementById('offline-screen').style.display = 'block'
      }
    })
  }, [])

  const logCurrentNetworkStatus = async () => {
    const status = await Network.getStatus()
    console.log('Network status:', status)
  }

  return (
    <div id="app">
      <div id='offline-screen'>
        <h1>You are offline</h1>
        <p>Please check your internet connection and try again.</p>
      </div>
      {/* Your application content */}
    </div>
  )

}

export default App

以下のスタイルをファイルに追加する App.css ファイル:

#offline-screen {
  display: none;
  text-align: center;
  padding: 20px;
  background-color: #f2f2f2;
}

#offline-screen h1 {
  font-size: 24px;
}

#offline-screen p {
  font-size: 16px;
}

ユーザーがオフラインになった場合、オフライン画面が表示されます。ユーザーがオンラインに戻った場合、オフライン画面が非表示になります。

サポートするメソッドとインターフェイス

APIネットワークは、ネットワーク接続を管理するためにいくつかのメソッドとインターフェイスを提供しています。以下は主なものです:

Capacitor アプリのリアルタイム更新

Capgo を使用して、ウェブ層のバグが生じた場合に、修正をアプリストアの承認待ちの日数を待たずに配信することができます。ユーザーはバックグラウンドで更新を受け取り、ネイティブの変更は通常のレビュー経路を通じて残ります。

スタートする

ブログの最新記事

Capgo を使用すると、プロフェッショナルなモバイルアプリを作成するために必要な最良の洞察を得ることができます。