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
Installation: Installez le plugin à l'aide de
npm i vite-plugin-pwa
.-
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 -
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 connexionLa fonction
registerSW
gère le cycle de vie des travailleurs du service. La logique conditionnelle (par exemple, à l'exclusionlocalhost
) empêche l'activation des travailleurs du service pendant le développement. 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 // ... } });
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 ... * /] } })
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"] } })
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

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

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds











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

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

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

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

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

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

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

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é
