Vue 2 如何添加 register-service-worker 以实现缓存请求的目的

news2025/2/28 11:18:22

Vue 2 如何添加 register-service-worker 以实现缓存请求的目的

一、问题描述

现在 vue 3 的模板中是自带 register-service-worker 的。
用这个的好处是,它会自动将项目中的所有文件请求缓存到 service-worker 中,以实现再次打开网站的时候会非常非常快。
如果页面中变化,也会自动在后台下载变化的文件,页面的变化在下次刷新页面的时候就会自动生效。

我有几个 Vue2 的项目需要实现这个功能,摸索了下,把结果分享一下:

二、实现

1. 需要在 package.json 中添加两个插件:

    "register-service-worker": "^1.7.2",  // 用于管理  service-worker 的文件注册更新等
    "@vue/cli-plugin-pwa": "^4.5.19",

安装 register-service-worker 安装到项目依赖目录 dependencies

npm i register-service-worker

安装 @vue/cli-plugin-pwa 安装到项目开发支持目录 devDependencies

npm i  -D @vue/cli-plugin-pwa@4.5.19

安装完成之后的 package.json 文件是这样的:

  "dependencies": {
    ...
    "register-service-worker": "^1.7.2",
    ...
  },
  "devDependencies": {
  	...
    "@vue/cli-plugin-pwa": "^4.5.19",
    ...
  }

2. 添加 registerServiceWorker.js

还需要在 /src 目录下,添加 registerServiceWorker.js 这个文件,这个文件的内容很固定,直接用就行。

官方的那个只能用于项目处于网站根目录的情况,而我自己有很多项目是部署在子目录的,比如 kylebing.cn/diary kylebing.cn/tools/wubi-dict-editor,那么此时再用官方的那个文件内容可能就不能用了。所以直接用我这个就行 。

registerServiceWorker.js 完整内容

/* eslint-disable no-console */

import { register } from 'register-service-worker'

if (process.env.NODE_ENV === 'production') {
  register(`${process.env.BASE_URL}service-worker.js`, {
    ready () {
      console.log(
        'App is being served from cache by a service worker.\n' +
        'For more details, visit https://goo.gl/AFskqB'
      )
    },
    registered () {
      console.log('Service worker has been registered.')
    },
    cached () {
      console.log('Content has been cached for offline use.')
    },
    updatefound () {
      console.log('New content is downloading.')
    },
    updated () {
      console.log('New content is available; please refresh.')
    },
    offline () {
      console.log('No internet connection found. App is running in offline mode.')
    },
    error (error) {
      console.error('Error during service worker registration:', error)
    }
  })
}

3. 在 main.js 中引入 registerServiceWorker.js 即可

在项目的 main.js 中引入 registerServiceWorker.js,再执行 npm build 即可生成能够缓存请求的项目了

我一般的项目入口文件名这 main.js,你的可能是 app.js,等同。

import "./registerServiceWorker"

4. 在 vue.config.js 中添加 pwa 配置

添加 pwa 支持之后, index.html 中的 favicon 设置就已经失效了,需要从 vue.config.jspwa 字段中单独配置。

在这里插入图片描述

/**
     * PWA 设置
     */
    pwa: {
        name: '地图工具', // 名字
        themeColor: "white", // 背景颜色
        appleMobileWebAppCapable: true, // 苹果 WebApp 支持

        // manifest 设置
        manifestOptions: {
            name: '地图工具',
            short_name: "地图工具",
            theme_color: "white",
            start_url: ".",
            display: "standalone",
            background_color: "white",
            icons: [
                {
                    src: "favicon.png", // 这里的图片地址对应 /public 目录中的图片地址
                    sizes: "512x512",
                    type: "image/png",
                    purpose: "any",
                }
            ],
        },

        // 图标
        iconPaths: {
            // 这里是项目外的路径,对应 public 目录
            favicon32: 'favicon.png', // 这里的图片地址对应 /public 目录中的图片地址
            favicon16: 'favicon.png', // 这里的图片地址对应 /public 目录中的图片地址
            maskIcon: null,
            msTileImage: null
        }
    }

之后就能正常显示了:

在这里插入图片描述

三、结果

首次加载页面的时候,注册了 service-worker.js
在这里插入图片描述

之后所有的文件都能够通过 service-worker 从缓存中获取了
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/9503.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2023最新SSM计算机毕业设计选题大全(附源码+LW)之java校园二手物品交易系统051x4

做毕业设计一定要选好题目。毕设想简单,其实很简单。这里给几点建议: 1:首先,学会收集整理,年年专业都一样,岁岁毕业人不同。很多人在做毕业设计的时候,都犯了一个错误,那就是不借鉴…

HTB-Tier1

HTB-Tier1 Appointment Task 1 What does the acronym SQL stand for? ********** ***** *******e Structured Query Language Hide Answer Task 2 What is one of the most common type of SQL vulnerabilities? *** ********n sql injection Hide Answer Task …

汉字风格迁移篇----EasyFont:一个基于风格学习的系统,可以轻松构建大规模手写字体

文章目录abstract1 INTRODUCTION2 RELATED WORK3 METHOD DESCRIPTION3.1 Selecting Input Character Set3.2 Learning Font Skeleton Manifold3.2.1 Character Matching.3.2.2 Training the GP-LVM3.3 Text Segmentation3.4 Stroke Extraction3.5 Overall Style Learning3.5.1 …

UNet - 数据加载 Dataset

目录 1. 介绍 2. 数据处理 dataset 2.1 预处理 2.2 加载数据 2.2.1 初始化 2.2.2 返回数据 2.2.3 样本数量 3. 测试一下 4. 完整代码 1. 介绍 之前介绍完了Unet网络的搭建,接下来说一下要解决的任务。 本章介绍的是:数据的加载处理 下面是整…

hadoop 3.3大数据集群搭建系列1-安装hadoop

文章目录一. 软硬件配置1.1 主机配置及规划1.2 软件配置1.3 安装常用的工具二. 安装前准备2.1 设置主机名2.2 设置hosts2.3 关闭防火墙2.4 ssh免密登陆2.5 ntpdate时间同步三. 安装3.1 安装hadoop3.1.1 下载hadoop并解压3.1.2 配置hadoop_home环境变量3.1.3 编辑etc/hadoop/had…

【毕业设计】图像识别垃圾分类系统 - python 深度学习

文章目录0 前言1 简介2 识别效果3 实现3.1 数据集3.2 实现原理和方法3.3 网络结构4 最后0 前言 🔥 Hi,大家好,这里是丹成学长的毕设系列文章! 🔥 对毕设有任何疑问都可以问学长哦! 这两年开始,各个学校对…

信息熵,交叉熵,KL散度,互信息一网打尽

talk 一直以来都是自己有时候 想去搞明白就搜搜博客看,模棱两可,记忆也比较模糊,这次直接较为系统的记录一下,之后忘了也能看看~ 1. 信息熵 这个概念是从信息论出现的,是香农定义的,根据事件发生的概率进…

excel怎么设置密码?加密文件这么做!

我们都知道,很多时候需要我们在电脑上保存很多excel文件。为了避免在工作中出现意外,我们需要在文件中设置一个安全密码。那么,电子表格excel怎么设置密码呢?如果我们设置了密码,想要取消原本的密码或者重新设置一个密…

Windows无法启动这个硬件设备(代码19)怎么办?

在我们使用电脑的过程中,遇到“由于其配置信息(注册表中的)不完整或已损坏,Windows无法启动这个硬件设备(代码19)”的提示时该如何解决呢? Windows无法启动这个硬件设备(代码19),如何…

干货整理| 深度学习入门知识

一、深度学习的定义 深度学习(Deep Learning),简称:DL,是一种实现机器学习的技术。 人工智能(AI)的概念是在1955 年提出的;机器学习(ML)概念是在1990 年提出…

springboot 整合clickhouse

最近需要做一个项目 需要整合clickhouse 本来有现成的项目,复制一下就好了。但是想自己从头开始一个个文件搭建 但是还是遇到了很多坑, 这就是传说中的约定优于配置吗 1 首先第一步application启动的时候 启动完了,就会退出&#xff0c…

[附源码]计算机毕业设计JAVA房屋租赁管理系统

[附源码]计算机毕业设计JAVA房屋租赁管理系统 项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybati…

C++QT实现压缩文件、文件夹和解压缩操作

一、前言 QZipWriter是用来压缩文件的类,需要在安装Qt是选择Sources源码安装。否则,无法使用QZipWriter。 1. QZipWriter函数说明 1.1 构造方法: QZipWriter(const QString &fileName, QIODevice::OpenMode mode (QIODevice::WriteOnl…

控制游戏人物移动的细节到底有多少?

👨‍💻个人主页:元宇宙-秩沅 hallo 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 秩沅 原创 收录于专栏 unity实战入门 在游戏中我们在做控制游戏物体移动时会碰到以下常见的几种情况: 文章目录在游戏中…

adb shell AT指令发送短信

开启两个,命令行窗口。都进入adb shell。 查看 /dev下的smd设备节点,选取一个进行读写操作 一个窗口用来进行读,另一个窗口进行写入指令操作,读取和写入的节点需要一致。 SH4-1:/ # ls /dev/smd* ls /dev/smd* /dev/smd11 /dev/…

隐式神经表示一:神经网络拟合图像Implicit Neural Representations with Periodic Activation Functions

文章目录1. Implicit Neural Representations with Periodic Activation Functions0. 什么是隐式神经表示1. 了解SineLayer的初始化,还是没了解。。。2. 均匀分布3. Lemma 1.14. 一个简单实验, 拟合图像4.1 网络模型代码如下,就是全连接网络,…

【自然语言处理(NLP)】基于BiLSTM+CRF的事件抽取

【自然语言处理(NLP)】基于BiLSTMCRF的事件抽取 作者简介:在校大学生一枚,华为云享专家,阿里云专家博主,腾云先锋(TDP)成员,云曦智划项目总负责人,全国高等学…

Centos 7 安装 wget

文章目录1. wget命令详解:2.查看帮助手册3.使用 wget 下载单个文件4.使用 wget -O 下载并以不同的文件名保存5.使用 wget -c 断点续传6.使用 wget -b 后台下载1. wget命令详解: wget是Linux中的一个下载文件的工具,wget是在Linux下开发的开放源代码的软件&#xff…

tomcat线程池-深度分析tomcat线程池设计与现实

1.概述 在正式进入Tomcat线程池之前,小伙伴们可以先回顾一下JDK中的线程池相关特性,对于JDK线程池的总结和源码的解析感兴趣的童鞋,也可参考博主的层层剖析线程池源码的这篇文章,文章主要讲述对线程池的生命周期,核心参…

五、事件系统-原生事件-react中的合成事件-详解事件的冒泡和捕获机制

目标 深入理解和掌握事件的冒泡及捕获机制理解react中的合成事件的本质在react组件中合理的使用原生事件 知识点 在原生的dom模型上触发的事件会进行事件传递。而所谓的事件传递指的是当在A元素上触发某一事件的时候,B元素如果满足了和A元素一定的关系的话&#xf…