1.什么是浏览器缓存
浏览器缓存(Browser Caching)是为了节约网络的资源加速浏览,浏览器在用户磁盘上对最近请求过的文档进行存储,当访问者再次请求这个页面时,浏览器就可以从
本地磁盘
显示文档,这样就可以加速页面的阅览
2.浏览器缓存类型
-
缓存协商:Last-modified ,Etag
-
彻底缓存(强制缓存):cache-control,Expires
3.浏览器缓存的优势与劣势
-
节约网络资源,提高网络效率
-
降低服务器压力,减少服务器负担
-
缓存没有清理机制
-
占用硬盘空间
-
页面缓存,导致页面样式、图片或脚本等未能及时更新展示
4. 浏览器缓存机制
查阅这里:
https://www.cnblogs.com/vajoy/p/5341664.html
还有这里:
https://blog.csdn.net/u014590757/article/details/80140654
还有这里:
https://www.jianshu.com/p/1a1536ab01f1
还有:
https://www.cnblogs.com/kevingrace/p/10459429.html
5.如何清除浏览器缓存
-
修改根目录index.htm 让所有的css/js资源重新加载
// index.html
<meta http-equiv="pragram" content="no-cache">
<meta http-equiv="cache-control" content="no-cache, no-store, must-revalidate">
</head>
-
配置 nginx 不缓存 html
vue默认配置,打包后css和js的名字后面都加了哈希值,不会有缓存问题。但是index.html在服务器端可能是有缓存的,需要在服务器配置不让缓存index.html
server {
listen 80;
server_name yourdomain.com;
location / {
try_files $uri $uri/ /index.html;
root /yourdir/;
index index.html index.htm;
if ($request_filename ~* .*\.(?:htm|html)$)
add_header Cache-Control "no-cache, no-store"; //对html文件设置永远不缓存
no-cache:数据内容不能被缓存, 每次请求都重新访问服务器, 若有max-age, 则缓存期间不访问服务器
no-store:不仅不能缓存, 连暂存也不可以(即: 临时文件夹中不能暂存该资源)
使用vue脚手架搭建的项目,打开vue.config.js
//vue.config.js
const version = new Date().getTime();
module.exports = {
css: {
// 是否使用css分离插件 ExtractTextPlugin
extract: {
// 修改打包后css文件名 // css打包文件,添加时间戳
filename: `css/[name].${version}.css`,
chunkFilename: `css/[name].${version}.css`
configureWebpack: {
output: { // 输出重构 打包编译后的 文件名称 【模块名称.版本号.时间戳】
filename: `[name].${process.env.VUE_APP_Version}.${Timestamp}.js`,
chunkFilename: `[name].${process.env.VUE_APP_Version}.${Timestamp}.js`
目录1.什么是浏览器缓存2.浏览器缓存类型:3.浏览器缓存的优势与劣势:4. 浏览器缓存机制5.如何清除浏览器缓存在代码更新发布后,都会要求运营人员在访问网址时清除下本地缓存,防止万一掉坑那问题就来了:每次清缓存很麻烦,怎样就不需要他们每次去手动清缓存呢?1.什么是浏览器缓存浏览器缓存(Browser Caching)是为了节约网络的资源加速浏览,浏览器在用户磁盘上对最近请求过的文档进行存储,当访问者再次请求这个页面时,浏览器就可以从本地磁盘显示文档,这样就可以加速页
每次把修改后的vue项目build构建的打包文件丢到线上服务器后,发现还是上一次的效果,新修改的不起效,每次都需要ctrl+F5强制刷新页面,用户太多不可能让所有人每次都这样去折腾,为啥?
vue cli不是给静态资源css、js、img自动加了哈希么,怎么还会有缓存?
经过多方调试,发现是因为入口文件index.html需要在服务器端设置禁止缓存。
解决缓存问题可以分两步走:
①nginx配置index不缓存
②代码加入版本更新检测强制刷新
解决方案一:(Linux服务器设置
configureWebpack: {
output: { // 输出重构 打包编译后的 文件名称 【模块名称.版本号(可选).时间戳】
filename: `[name].${Timestamp}.js`,
最近客户和我反应一个问题他们在服务器上更新包后,发现页面并没有更新,而且简单刷新浏览器页面也没有效果,必须要清理浏览器缓存,页面才会刷新。
提示:以下是本篇文章正文内容,下面案例可供参考
一、为什么会这样?
仔细看引用的js 发现更新前后 引用的JS路径是一样的,而js是从服务器上下载本地浏览器的,如果不刷新浏览器缓存。更新后引用JS,CSS,还有一些静态资源还都是浏览器缓存中
二、如何解决
既然引用地址没有变化,
如果是用vue做的单页面程序的时候,将监听的方法放在App.vue是最灵活的
&amp;lt;template&amp;gt;
&amp;lt;div id=&quot;main&quot; class=&quot;app-main&quot;&amp;gt;
&amp;lt;router-view&amp;gt;&a
Vue.js是一个JavaScript框架,用于构建用户界面。在使用Vue.js开发网站时,由于浏览器缓存的存在,可能会导致版本更新的问题。
浏览器缓存是指浏览器在第一次请求网页后,会将该网页的一些资源文件(例如JavaScript和CSS文件)保存在本地。当用户再次访问相同的网页时,浏览器会直接从本地缓存中加载这些资源文件,以提高网页的加载速度。
然而,当使用Vue.js进行版本更新时,如果浏览器继续使用缓存的旧版本文件,就会导致网页显示异常或出现错误。为了解决这个问题,可以采取以下几种方法:
1. 使用文件版本号:在引入CSS和JavaScript文件时,可以在文件名中添加一个版本号,例如app.js?v=1.0。每次更新版本时,只需修改版本号即可,这样浏览器会认为是不同的文件,强制重新加载。
2. 添加Cache-Control头信息:通过在服务器端的响应头信息中添加Cache-Control字段,指定浏览器是否应该缓存文件,以及缓存的有效期。通过设置"no-cache"或"no-store"可以禁止浏览器缓存文件。
3. 使用Webpack的chunkhash:在使用Webpack打包项目时,可以使用chunkhash生成唯一的文件名,例如app.f8293f3.js。每次更新时,Webpack会自动生成新的chunkhash,从而强制浏览器重新加载文件。
除了以上方法,还可以使用一些高级技术,如Service Worker来实现离线缓存和更新策略,或使用CDN来分发文件,以避免缓存问题。
总而言之,更新Vue.js版本时,需要考虑到浏览器缓存的存在。通过使用文件版本号、设置Cache-Control头信息或使用Webpack的chunkhash等方法,可以解决浏览器缓存问题,确保网页能够正确加载最新的文件。