添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
相关文章推荐
仗义的夕阳  ·  [开源]基于 ...·  1 月前    · 
任性的筷子  ·  weka ...·  1 年前    · 

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;amp;lt;template&amp;amp;gt; &amp;amp;lt;div id=&amp;quot;main&amp;quot; class=&amp;quot;app-main&amp;quot;&amp;amp;gt; &amp;amp;lt;router-view&amp;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等方法,可以解决浏览器缓存问题,确保网页能够正确加载最新的文件。