Zum Hauptinhalt springen
Tutorial

Offline-Bildschirm in Vue, Angular, React mit Capacitor

Erfahren Sie, wie Sie einen Offline-Bildschirm in Vue, Angular- oder React-Anwendungen mit dem Netzwerk API und Capacitor implementieren können. Verbessern Sie die Benutzererfahrung, indem Sie Offline-Szenarien effektiv handhaben.

Martin Donadieu

Martin Donadieu

Content-Marketing-Beauftragter

Offline-Bildschirm in Vue, Angular, React mit Capacitor

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:

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:

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.

Live-Updates für Capacitor-Apps

Wenn ein Web-Schicht-Bug live ist, liefern Sie die Reparatur über Capgo anstatt Tage auf die App-Store-Zulassung zu warten. Die Benutzer erhalten die Aktualisierung im Hintergrund, während native Änderungen im normalen Review-Prozess bleiben.

Los geht's jetzt

Aktuelle Beiträge aus unserem Blog

Capgo bietet Ihnen die besten Einblicke, die Sie benötigen, um eine echte professionelle Mobil-App zu erstellen.