Maison interface Web tutoriel CSS Utilisation du plugin Vitepwa pour un site hors ligne

Utilisation du plugin Vitepwa pour un site hors ligne

Mar 15, 2025 am 09:12 AM

Utilisation du plugin Vitepwa pour un site hors ligne

Le plugin Vitepwa d'Anthony Fu est un outil puissant pour améliorer les sites Web basés sur VITE avec des fonctionnalités hors ligne. Ce plugin simplifie le processus d'ajout d'un employé de service pour gérer le support hors ligne, la mise en cache des actifs et les notifications de mise à jour. Explorons les travailleurs des services et comment les mettre en œuvre à l'aide de Vitepwa.

Comprendre les travailleurs du service

Un travailleur de service est un script d'arrière-plan exécutant indépendamment de votre application Web. Sa fonction clé est d'intercepter les demandes de réseau, permettant diverses actions. Bien que capable de tâches complexes comme la compilation de typescript à la volée ou le transcodage vidéo, son utilisation la plus courante est la mise en cache des actifs pour l'amélioration des performances et l'accès hors ligne.

Vitepwa crée un travailleur de service qui pré-cache des fichiers HTML, CSS et JavaScript lors de la visite initiale du site. Les visites suivantes chargent ces ressources à partir du cache, éliminant les demandes de réseau. Même lors de la première visite, les clics ultérieurs chargent souvent le contenu pré-cache, améliorant considérablement la vitesse.

Versioning et manifester les fichiers

La gestion des mises à jour des travailleurs de service lorsque les modifications de code nécessitent un versioning minutieux. Les systèmes de construction génèrent généralement des noms de fichiers (par exemple, foo-ABC123.js ) incorporant des hachages de fichiers. Les mises à jour entraînent de nouveaux noms de fichiers (par exemple, foo-XYZ987.js ). Le travailleur des services doit gérer ces changements efficacement.

L'API des travailleurs de service est de bas niveau. La gestion manuelle des fichiers en cache est complexe. Workbox, une bibliothèque Google, simplifie cela, mais nécessite toujours des informations détaillées sur les actifs de votre processus de construction. Vitepwa aborde l'élégance en s'intégrant à Workbox et en le configurant automatiquement avec la sortie de build de Vite.

Mise en œuvre d'un employé de service avec Vitepwa

  1. Installation: Installez le plugin à l'aide de npm i vite-plugin-pwa .

  2. Configuration VITE: Importez et ajoutez le plugin à votre vite.config.js :

     import {Veepwa} à partir de "Vite-Plugin-PWA";
    
    Exporter de défaut DefiConfig ({
      Plugins: [VitePwa ()],
      // ... Autres configurations
    });
    Copier après la connexion
  3. Inscription des travailleurs de service: enregistrez le fonctionnaire au point d'entrée de votre demande:

     import {registrersw} de "virtual: pwa-register";
    
    if ("ServiceWorker" dans Navigator) {
      registresw (); // Envisagez d'ajouter une logique conditionnelle pour les environnements de développement
    }
    Copier après la connexion

    La fonction registerSW gère le cycle de vie des travailleurs du service. La logique conditionnelle (par exemple, à l'exclusion localhost ) empêche l'activation des travailleurs du service pendant le développement.

  4. Fonctionnalité hors ligne: la pré-cache fournie par Vitepwa permet automatiquement les fonctionnalités hors ligne de base. Les actifs sont servis à partir du cache même sans accès au réseau. Pour les capacités hors ligne plus avancées (par exemple, en utilisant IndededDB), une logique de travailleur de service personnalisé est nécessaire.

Mises à jour des travailleurs du service

Lorsque le code change, un nouveau travailleur de service avec un manifeste pré-cache mis à jour est généré. L'ancien travailleur de service continue de fonctionner jusqu'à ce que tous les onglets soient fermés et rouverts, garantissant une expérience utilisateur cohérente entre les sessions.

Amélioration de la gestion de la mise à jour avec onNeedRefresh

La fonction registerSW permet un processus de mise à jour plus lisse. Le rappel onNeedRefresh est déclenché lorsqu'un nouveau travailleur de service est disponible, offrant une occasion d'informer l'utilisateur et de lancer un rechargement contrôlé:

 registrersw ({
  onneedRefresh () {
    // affiche une notification à l'utilisateur, ce qui les incite à mettre à jour
    // ...
  }
});
Copier après la connexion

Cache d'exécution

L'option de configuration workbox de VITEPWA permet la mise en cache d'exécution pour les actifs récupérés lors de l'exécution de l'application. Cela étend les capacités hors ligne au-delà des ressources pré-caches:

 Vitepwa ({
  Workbox: {
    RuntimeCaching: [/ * ... vos configurations de mise en cache d'exécution ... * /]
  }
})
Copier après la connexion

Ajout d'un code de travailleur de service personnalisé

Pour intégrer la logique personnalisée, utilisez l'option importScripts dans la configuration workbox pour inclure des fichiers JavaScript externes:

 Vitepwa ({
  Workbox: {
    importations: ["sw-code.js"]
  }
})
Copier après la connexion

Conclusion

Veepwa simplifie considérablement la mise en œuvre des travailleurs des services, fournissant une base robuste pour les fonctionnalités hors ligne et les performances améliorées. Bien que les fonctionnalités avancées nécessitent du code personnalisé, le plugin gère les complexités de la mise en cache et des mises à jour, permettant aux développeurs de se concentrer sur la logique d'application. Commencez avec des capacités hors ligne et explorez des fonctionnalités de travailleurs de service plus avancées au besoin.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

<🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
<🎜>: Grow A Garden - Guide de mutation complet
3 Il y a quelques semaines By DDD
Nordhold: Système de fusion, expliqué
4 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Comment déverrouiller le grappin
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Tutoriel Java
1671
14
Tutoriel PHP
1276
29
Tutoriel C#
1256
24
Une comparaison des fournisseurs de formulaires statiques Une comparaison des fournisseurs de formulaires statiques Apr 16, 2025 am 11:20 AM

Essayons de savoir un terme ici: "fournisseur de formulaire statique". Vous apportez votre HTML

Une preuve de concept pour rendre Sass plus rapidement Une preuve de concept pour rendre Sass plus rapidement Apr 16, 2025 am 10:38 AM

Au début d'un nouveau projet, la compilation SASS se produit en un clin d'œil. Cela se sent bien, surtout quand il est associé à BrowSersync, qui recharge

Actualités hebdomadaires de la plate-forme: attribut HTML Loading, les principales spécifications Aria et le passage de iframe à Shadow Dom Actualités hebdomadaires de la plate-forme: attribut HTML Loading, les principales spécifications Aria et le passage de iframe à Shadow Dom Apr 17, 2025 am 10:55 AM

Dans cette semaine, le Roundup des nouvelles de la plate-forme, Chrome présente un nouvel attribut pour le chargement, les spécifications d'accessibilité pour les développeurs Web et la BBC Moves

Certains pratiques avec l'élément de dialogue HTML Certains pratiques avec l'élément de dialogue HTML Apr 16, 2025 am 11:33 AM

C'est moi qui regarde l'élément HTML pour la première fois. J'en ai été conscient depuis un certain temps, mais il ne l'a pas encore pris pour un tour. Il a un peu cool et

Forme de papier Forme de papier Apr 16, 2025 am 11:24 AM

L'achat ou la construction est un débat classique de la technologie. Construire des choses vous-même peut être moins cher car il n'y a pas d'article de ligne sur votre facture de carte de crédit, mais

Où devrait «abonner au podcast» vers le lien? Où devrait «abonner au podcast» vers le lien? Apr 16, 2025 pm 12:04 PM

Pendant un certain temps, iTunes était le grand chien du podcasting, donc si vous avez lié "Abonnez-vous au podcast" pour aimer:

Actualités de plate-forme hebdomadaire: bookmarklet d'espacement de texte, attente de haut niveau, nouvel indicateur de chargement d'ampli Actualités de plate-forme hebdomadaire: bookmarklet d'espacement de texte, attente de haut niveau, nouvel indicateur de chargement d'ampli Apr 17, 2025 am 11:26 AM

Au cours de cette semaine, un Bookmarklet pratique pour inspecter la typographie, en utilisant Await pour bricoler comment les modules JavaScript s'importent, ainsi que Facebook & # 039; S

Options pour héberger vos propres analyses non-javascript Options pour héberger vos propres analyses non-javascript Apr 15, 2025 am 11:09 AM

Il existe de nombreuses plates-formes d'analyse pour vous aider à suivre les données des visiteurs et d'utilisation sur vos sites. Peut-être plus particulièrement Google Analytics, qui est largement utilisé

See all articles