Affichage d'une page hors ligne personnalisée uniquement en pwa angulaire lorsqu'aucune connexion Internet n'est disponible

Aug 18 2020

dans Angular 9+, je voudrais ajouter une page hors ligne personnalisée (fichier .html et .scss) .J'ai converti mon application angulaire en pwa en suivant toutes les étapes de base nécessaires pour un pwa angulaire. Mais j'ai des problèmes avec le pwa. J'ai déjà appliqué une interface de service de connexion pour surveiller la connectivité réseau dans app.component.ts. la page hors ligne s'exécute lorsqu'il n'y a pas de réseau mais au moment où j'appuie sur le bouton d'actualisation, le navigateur s'actualise sans en afficher aucun hors ligne. Je veux implémenter le hors ligne de telle manière que si l'utilisateur appuie sur le lien d'actualisation, le navigateur s'actualise mais affiche également la même page hors ligne s'il n'y a pas de réseau. Angular PWA avec page hors ligne personnalisée (j'ai essayé de créer un sw.js personnalisé mais cela me donne toujours une erreur d'enregistrement).

app.component.ts

constructor( connectionService:ConnectionService) {
            this.conCheck()
           }
conCheck(){
this.connectionService.monitor().subscribe( conn => {
  this.isConnection = conn;
  if(this.isConnection){
    this.util.showSuccess("You are Connected.")
  }else{
    this.util.showError("Please check your internet connection.")
  }
})

app.component.html

<div *ngIf="isConnection ; else offline">
<router-outlet></router-outlet></div>
<ng-template #offline>
<app-network-checker></app-network-checker></ng-template>

ngsw-config.json

"files": [
      "/favicon.ico",
      "/*.css",
      "/*.js",
      "/assets/offline.html"
    ]

app.module.ts

imports: [
  ServiceWorkerModule.register('ngsw-worker.js', { enabled: environment.production , registrationStrategy:"registerImmediately" })

network-checker.component.html (page hors ligne)

<main>
<a href="#">refresh</a>
</maine>

Réponses

TheJames Aug 18 2020 at 17:40

Vous pouvez créer un garde-route qui utilise ConnectionService pour vérifier l'état de chaque tentative d'acheminement. C'est probablement la solution la plus simple et le garde-route serait réutilisable pour toutes les routes.