Vue 3、Angular 14、またはReactでオフライン画面を作成する方法
このチュートリアルでは、Vue 3、Angular 14、Reactアプリケーションでオフライン画面を作成する方法を学びます。Network APIを使用すると、ネットワークと接続性に関する情報を取得できます。Network APIを使用すると、オフラインシナリオを処理し、ユーザー体験を向上させることができます。
前提条件
チュートリアルを始める前に、以下をインストールしてください:
- Node.js (version 14 or higher)
- Vue CLI
- Angular CLI
- Create React App
プロジェクトの設定
まず、各フレームワークのためのプロジェクト用のスケルトンを使用して、新しいプロジェクトを作成しましょう。
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ネットワークは、ネットワーク接続を管理するためにいくつかのメソッドとインターフェイスを提供しています。以下は主なものです:
getStatus(): ネットワーク接続の現在の状態を照会するaddListener('networkStatusChange', ...): ネットワーク接続の変更をリスンする