vue项目引入pwa使网页应用可安装

news2024/12/23 7:00:27

最近在使用vue项目时看到一个这样的效果,如图:

在这里插入图片描述
现在其实有很多网站都支持把网页安装到电脑或手机(IOS Safari支持较好),如下图安装后的效果:
在这里插入图片描述

在这里插入图片描述

这些都是网页应用。

接下来介绍一下如何让你的vue2项目变得可以安装。

添加cli-plugin-pwa

给现有的vue项目添加,使用下面命令:

vue add pwa

执行完之后会自动在package.json添加"@vue/cli-plugin-pwa",“register-service-worker” 依赖。

并且在项目src目录下生成registerServiceWorker.js和service-worker.js文件:

// 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)
    }
  })
}

// service-worker.js 略有改动 以你自己的为准
// install new service worker when ok, then reload page.
self.addEventListener("message", msg => {
  if (msg.data && msg.data.type === 'SKIP_WAITING'){
      self.skipWaiting()
  }
})

而且还会在public/img/icons下生成适用于个平台安装的默认图标,可以自己生成替换即可。

然后需要手动在main.js引入 registerServiceWorker.js

import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
import './registerServiceWorker'

Vue.config.productionTip = false

new Vue({
  router,
  store,
  render: h => h(App)
}).$mount('#app')

最后到vue.config.js中添加相关配置:

module.exports = {
	pwa: {
	    name: "My App",
	    themeColor: "#000000",
	    msTileColor: "#000000",
	    appleMobileWebAppCapable: "yes",
	    appleMobileWebAppStatusBarStyle: "black",
	    assetsVersion: "1.2",
	    iconPaths: {
	      favicon32: "img/icons/favicon-32x32.png",
	      favicon16: "img/icons/favicon-16x16.png",
	      appleTouchIcon: "img/icons/apple-touch-icon.png",
	      maskIcon: "img/icons/safari-pinned-tab.svg",
	      msTileImage: "img/icons/msapplication-icon-144x144.png",
	    },
	    manifestOptions: {
	      icons: [
		      {
			      src: "./img/icons/android-chrome-192x192.png",
			      sizes: "192x192",
			      type: "image/png",
		      },
		      {
			      src: "./img/icons/android-chrome-256x256.png",
			      sizes: "256x256",
			      type: "image/png",
		      },
		      {
			      src: "./img/icons/apple-touch-icon.png",
			      sizes: "120x120",
			      type: "image/png",
		      }
	      ],
    	},
	    workboxPluginMode: "InjectManifest",
	    workboxOptions: {
	        swSrc: "src/service-worker.js"
	    },
  	},
}

这样重新把项目部署后,刷新页面后你的网站地址栏已经出现可安装的图标。

在这个基础上,可以解决一个spa项目的一个痛点,就是每次重新部署后客户端缓存问题,通过service worker可以提示用户有新的可用版本。

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

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

相关文章

动态规划刷题篇【Day01】

目录 一.问题描述 描述 二.示例 三.动态规划方法 (一)最优子结构 (二)递推关系建立 (三)自底向上计算 (四)代码实现 一.问题描述 描述 输入一个长度为n的整型数组array&#xff…

Echarts 箱线图的详细配置过程

文章目录 Echarts 简介 Echarts 简介 ECharts(百度开源的数据可视化库)提供了丰富的图表类型,其中包括箱线图。箱线图是一种用于展示数据分布情况的图表类型,它可以显示数据的中位数、四分位数、最大值、最小值和异常值等信息。下…

23种设计模式之工厂方法模式

前言:大家好,我是小威,24届毕业生,在一家满意的公司实习。本篇文章将23种设计模式中的工厂方法模式,此篇文章为一天学习一个设计模式系列文章,后面会分享其他模式知识。 如果文章有什么需要改进的地方还请大…

水提金银花多糖通过调节NLRP3-IL-17信号轴减轻过敏性鼻炎

文章标题:Water-extracted Lonicera japonica polysaccharide attenuates allergic rhinitis by regulating NLRP3-IL-17 signaling axis 发表期刊:Carbohydrate Polymers 影响因子:10.723 作者单位:遵义医科大学 百趣提供服务…

五、Spring Cloud Alibaba-Feign

引入 基于之前的学习,我们目前调用是通过restTemplate硬编码方式调用的。 restTemplate.getForObject("http://stock-service/stock/reduce", String.class);还是很不方便,考虑直接用service.方法进行调用,从而引出Feign&#xff…

vue+elementui+nodejs校园高校餐厅点餐及订餐菜品推荐评价系统6927k

传统的销售模式,在实体店的紧跟式的销售模式,会给消费者一种不自由,被监视的感觉。餐厅点餐及推荐系统,紧跟数据时代的步伐,使用nodejs开发语言,配备MySQL数据库。扎根于实际问题所开发出来的一套系统。这个…

总结845

学习目标: 月目标:5月(张宇强化前10讲,背诵15篇短文,熟词僻义300词基础词) 周目标:张宇强化前3讲并完成相应的习题并记录,英语背3篇文章并回诵 每日必复习(5分钟&#…

Windows 10 安装 MySQL

确认是否已安装 MySQL (1)按【winr】快捷键打开运行; (2)输入 services.msc; (3)点击【确定】,在打开的服务列表中查找 mysql 服务,如果没有 mysql 服务&…

HTAP for MySQL 在腾讯云数据库的演进

摘要:MySQL在充分利用多核计算资源方面比较欠缺,无法同时满足在线业务和分析型业务的客户需求,而单独部署一套专用的分析型数据库意味着额外的成本和复杂的数据链路。本次主题将介绍腾讯云数据库为满足此类场景而在HTAP for MySQL产品方面进行…

【数据挖掘与商务智能决策】第十五章 智能推荐系统 - 协同过滤算法

第十五章 智能推荐系统 - 协同过滤算法 15.2 相似度计算三种常见方法 15.2.1 欧式距离 import pandas as pd df pd.DataFrame([[5, 1, 5], [4, 2, 2], [4, 2, 1]], columns[用户1, 用户2, 用户3], index[物品A, 物品B, 物品C]) df用户1用户2用户3物品A515物品B422物品C421 …

【AI大模型】SparkDesk讯飞星火认知大模型初体验-持续更新

文章目录 SparkDesk讯飞星火认知大模型简介语言理解知识问答逻辑推理数学题解答代码理解与编写写在最后 SparkDesk讯飞星火认知大模型简介 科大讯飞推出的新一代认知智能大模型,拥有跨领域的知识和语言理解能力,能够基于自然对话方式理解与执行任务。从海…

6.其他函数

1.时间日期类 -- current_date() 返回当前日期 -- date_add(date, n) 返回从date开始n天之后的日期 -- date_sub(date, n) 返回从date开始n天之前的日期 -- datediff(date1, date2) 返回date1-date2的日期差 -- year(date) 返回…

港联证券|“牛市旗手”频遭股东减持 机构仍看好板块后市表现

5月8日,证券板块再迎爆发。截至收盘,中国银河盘中触及涨停,收盘涨超7%,中银证券涨超5%,信达证券、光大证券、招商证券涨超4%。板块回暖之际,多家券商二季度却遭遇股东减持。业内人士认为,减持计…

算法--扫描线

写在前面: 这个算法理解还是挺好理解的,就是到后面解决面积并问题的时候开始难理解了,看了半天,主要是还有其他的知识没理解就开始搞这个了。虽然最后还是直接懂了。 文章目录 扫描线算法的介绍一维问题LintCode 391 数飞机题目…

【历史上的今天】5 月 9 日:中国黄页上线;Red Hat 创始人出生;Scratch 2.0 发布

整理 | 王启隆 透过「历史上的今天」,从过去看未来,从现在亦可以改变未来。 今天是 2023 年 5 月 9 日,在 1993 年的今天,第一届东亚运动会在上海隆重开幕,这是亚洲体育运动史上的新篇章。来自东亚地区的中国、日本、…

【笔记】【HTTP】《图解HTTP》第5章 与HTTP协做的Web服务器

前言 有输入就要有产出,该笔记是本人看完《图解HTTP》后对每章涉及到的知识进行汇总博客将会已书的每章为一篇发布,下一篇博客发布时间不确定笔记中有些个人理解后整理的笔记,可能有所偏差,也恳请读者帮忙指出,谢谢。…

信号signal编程测试

信号会打断系统调用,慎用,就是用的时候测一测。 下面是信号的基础测试 信号 信号(signal)机制是UNIX系统中最为古老的进程之间的通信机制。它用于在一个或多个进程之间传递异步信号。信号可以由各种异步事件产生,例如…

数据结构与算法1:引入概念

接下来系统的学一下数据结构与算法的知识,本章节是第一部分:数据结构与算法的进入与基本概述 第一章:引入概念 【铁打的算法demo】先来看到题: 如果 a b c 1000,且 a2 b2 c2(a, b , c 为⾃然数&…

快进来,带你了解FPGA基础知识---lattice莱迪斯深力科MachXO2 FPGA系列简介

FPGA基础知识---lattice莱迪斯深力科MachXO2 LCMXO2-4000HC-4TG144I FPGA简介 FPGA基础知识:FPGA是英文Field-Programmable Gate Array的缩写,即现场可编程门阵列,它是在PAL、GAL、CPLD等可编程器件的基础上进一步发展的产物。它…

《程序员面试金典(第6版)》面试题 16.17. 连续数列(贪心算法思想,动态规划算法思想,C++)

题目描述 给定一个整数数组,找出总和最大的连续数列,并返回总和。 示例: 输入: [-2,1,-3,4,-1,2,1,-5,4] 输出: 6 解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。进阶: 如果你已经实…