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 taches 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 });
-
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 }
La 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

Undress AI Tool
Images de déshabillage gratuites

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.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à 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

CSS bloque le rendu de la page car les navigateurs affichent le CSS en ligne et le CSS externe comme des ressources clés par défaut, en particulier avec les feuilles de styles importées, les grandes quantités de CSS en ligne et les styles de requête multimédia non optimisés. 1. Extraire CSS critique et l'intégrez-la dans HTML; 2. Retard Chargement CSS non critique via JavaScript; 3. Utilisez des attributs multimédias pour optimiser le chargement tel que les styles d'impression; 4. Comprimer et fusionner CSS pour réduire les demandes. Il est recommandé d'utiliser des outils pour extraire les CS de clé, combiner le chargement asynchrone rel = "précharge" et utiliser le chargement retardé des médias raisonnablement pour éviter une division excessive et un contr?le de script complexe.

TheBestApproachForCSSDependSonTheproject'sspecificneeds.ForLargerProjects, externalcsisBetterDueTomaintainiabilityAndReUsability; ForsmallerProjectsorSingle-pageApplications, internecssigh

NON, CSSDOOSNOTHAVETOBEINLOWLOWERCASE.CI, USING USINGERCASERASERISROMEND pour: 1) Cohérence et réadaptation, 2) évitant les technologies de perception liées à la pertinence, 3) Potentiel PerformanceBenefits, and4) Amélioration de la collaboration.

CSSismostlyCase-insensible, buturlsandfontfamilyNamesaSaSase-sensible.1) Propriéties andvaluesLikEcolor: Red; arenotcase-sensible.2) UrlSMustMatchTheServer'scase, par exemple, / images / Logo.png.3) FontFamilyNamesliNe'apensans's'mUstBeexact.

AutoPrefixer est un outil qui ajoute automatiquement les préfixes des fournisseurs aux attributs CSS en fonction de la portée du navigateur cible. 1. Il résout le problème de maintenir manuellement les préfixes avec des erreurs; 2. Travaillez le formulaire de plug-in PostCSS, analyse CSS, analysez les attributs qui doivent être préfixés et générer du code en fonction de la configuration; 3. Les étapes d'utilisation incluent l'installation de plug-ins, la définition de la liste de navigateurs et leur permettant dans le processus de construction; 4. Les notes ne comprennent pas manuellement les préfixes, le maintien des mises à jour de la configuration, les préfixes pas tous des attributs, et il est recommandé de les utiliser avec le préprocesseur.

CSSCOUNTERSCANAUTOMAMATIQUE UNEUXESECTIONS ET LISTS.1) USECOUNTER-RESEDTOINITINALIALIALISE, COMPTENDREMENTTOINCREAD, andCounter () Orcounters () toDisplayValues.2) combinewithjavascriptfordynamiccontentoenSureAcurateupdates.

Dans CSS, les noms de sélecteur et d'attribut sont sensibles à la casse, tandis que les valeurs, les couleurs nommées, les URL et les attributs personnalisés sont sensibles à la casse. 1. Les noms de sélecteur et d'attribut sont insensibles à la casse, tels que la couleur arrière et la couleur arrière-plan sont les mêmes. 2. La couleur hexadécimale de la valeur est sensible à la casse, mais la couleur nommée est sensible à la casse, comme le rouge et le rouge n'est pas valide. 3. Les URL sont sensibles à la casse et peuvent causer des problèmes de chargement de fichiers. 4. Les propriétés personnalisées (variables) sont sensibles à la caisse, et vous devez faire attention à la cohérence du cas lorsque vous les utilisez.

CSSSelectorSandProperTyNamesaSaCase-insensible, tandis que les valeurs de canueSCanBECase-SensivedEprendContex
