How to Create an Offline Screen in Vue 3, Angular 14, or React
In diesem Tutorial lernen wir, wie man eine Offline-Anzeige in Vue 3, Angular 14 und React-Anwendungen erstellt, indem man den Netzwerkstatus API verwendet. Der Netzwerkstatus API liefert Informationen über das Netzwerk und die Verbindung, sodass wir Offline-Szenarien handhaben und einen besseren Benutzererlebnis bieten können.
Voraussetzungen
Bevor wir beginnen, stellen Sie sicher, dass Sie die folgenden installiert haben:
- Node.js (Version 14 oder höher)
- Vue CLI
- Angular CLI
- Create React App
Projekt einrichten
Zuerst erstellen wir ein neues Projekt mit dem jeweiligen Scaffold-Tool für jedes Framework.
Vue 3
Öffnen Sie Ihr Terminal und führen Sie den folgenden Befehl aus, um ein neues Vue 3-Projekt zu erstellen:
vue create offline-screen-vue3
Wählen Sie das Standardpaket und warten Sie, bis das Projekt erstellt ist.
Angular 14
Öffnen Sie Ihr Terminal und führen Sie den folgenden Befehl aus, um ein neues Angular 14-Projekt zu erstellen:
ng new offline-screen-angular14
Folgen Sie den Anweisungen, und wenn Sie nach zusätzlichen Funktionen gefragt werden, wählen Sie "Routing" aus, indem Sie die Leertaste drücken.
Wait for the project to be created.
React
npx create-react-app offline-screen-react
Öffnen Sie Ihr Terminal und führen Sie den folgenden Befehl aus, um ein neues React-Projekt zu erstellen:
Installing the Network API
Installieren Sie das Netzwerk __CAPGO_KEEP_0__. @capacitor/network Paket, das die Netzwerk API bereitstellt.
Öffnen Sie Ihr Terminal und navigieren Sie zu Ihrem Projektverzeichnis. Dann führen Sie den folgenden Befehl aus, um das Paket zu installieren:
npm install @capacitor/network
Für Capacitor-Projekte führen Sie auch den folgenden Befehl aus, um die native Projektdateien zu synchronisieren:
npx cap sync
Stellen Sie sicher, dass Sie das Capacitor CLI global installiert haben, indem Sie den folgenden Befehl ausführen:
npm install -g @capacitor/cli
Implementierung der Offline-Schaltfläche
Als Nächstes werden wir die Offline-Schaltflächenvorlage in jedem Framework implementieren. Wir werden eine einfache Nachricht anzeigen, wenn der Benutzer offline geht.
Vue 3
Öffnen Sie in Ihrem Vue 3-Projekt das src/main.js Datei und importieren Sie das Network Modul aus @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);
};
In Ihrem Anwendungs-Template (App.vuehinzufügen <div> Element mit der ID von offline-screen um die Offline-Bildschirmmeldung anzuzeigen:
<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>
Wenn der Benutzer offline geht, wird der Offline-Bildschirm angezeigt. Wenn der Benutzer wieder online ist, wird der Offline-Bildschirm verborgen.
Angular 14
In Ihrem Angular 14-Projekt öffnen Sie das src/app/app.component.ts Datei und importieren Sie das Network Modul aus @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);
};
}
In Ihrem Anwendungs-Template (app.component.html), fügen Sie ein <div> Element mit der ID von offline-screen um die Offline-Bildschirmmeldung anzuzeigen:
<div id="offline-screen">
<h1>You are offline</h1>
<p>Please check your internet connection and try again.</p>
</div>
<!-- Your application content -->
Fügen Sie folgende Styles hinzu zum app.component.css datei:
#offline-screen {
display: none;
text-align: center;
padding: 20px;
background-color: #f2f2f2;
}
#offline-screen h1 {
font-size: 24px;
}
#offline-screen p {
font-size: 16px;
}
Jetzt, wenn der Benutzer offline geht, wird das Offline-Bildschirm angezeigt. Wenn der Benutzer wieder online kommt, wird das Offline-Bildschirm verborgen.
React
Öffnen Sie in Ihrem React-Projekt die src/App.js datei und importieren Sie das Network Modul aus @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
Fügen Sie den folgenden Styles zur App.css datei hinzu:
#offline-screen {
display: none;
text-align: center;
padding: 20px;
background-color: #f2f2f2;
}
#offline-screen h1 {
font-size: 24px;
}
#offline-screen p {
font-size: 16px;
}
Jetzt, wenn der Benutzer offline geht, wird das Offline-Bildschirm angezeigt. Wenn der Benutzer wieder online kommt, wird das Offline-Bildschirm verborgen.
Unterstützende Methoden und Interfaces
Der Netzwerk API bietet mehrere Methoden und Interfaces, um Ihnen dabei zu helfen, die Netzwerkverbindung zu handhaben. Hier sind einige der wichtigsten:
getStatus(): Abfragen Sie den aktuellen Status der Netzwerkverbindung.addListener('networkStatusChange', ...): Netzwerkverbindungsänderungen abrufen.
Fortsetzen Sie von der Offline-Anzeige in Vue, Angular, React mit Capacitor.
Wenn Sie native Medien- und Schnittstellenverhalten planen, verbinden Sie es mit Offline-Anzeige in Vue, Angular, React mit Capacitor zur Verbindung mit Verwenden Sie @capgo/capacitor-live-aktivitäten zur nativen Fähigkeit in Verwenden Sie @capgo/capacitor-live-aktivitäten, @capgo/capacitor-live-aktivitäten zur Implementierungsdetail in @capgo/capacitor-live-aktivitäten, Verwenden Sie @capgo/capacitor-video-player zur nativen Fähigkeit in Verwenden Sie @capgo/capacitor-video-player, @capgo/capacitor-video-player für die Implementierungsdetails in @capgo/capacitor-Video-Player und Mit @capgo/capacitor-Native-Navigation für die native Fähigkeit in Mit @capgo/capacitor-Native-Navigation.