前端项目打包部署后如何避免让用户强制去清除浏览器缓存

 更新时间:2024年12月06日 09:21:58   作者:gumini  
这篇文章主要介绍了前端项目打包部署后如何避免让用户强制去清除浏览器缓存的相关资料,文中讲解了浏览器缓存机制及其对性能优化的重要性,探讨了如何通过设置Cache-Control头部、添加资源版本号或利用Webpack的文件命名特性来控制缓存,需要的朋友可以参考下

浏览器缓存机制

浏览器缓存是Web浏览中一个重要的性能优化机制,它允许浏览器将从服务器获取的资源(如HTML文件、图片、CSS样式表、JavaScript脚本等)存储在本地的临时存储区域。这样,在用户再次访问同一个网站或重复加载相同资源时,浏览器可以直接从本地缓存中读取这些资源,而不需要重新向服务器发送请求,从而大大加快了页面的加载速度,减少了网络流量消耗,并提升了用户体验。

解决方案

1、使用Cache-ControlPragma头部,禁止浏览器缓存。

<meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate">
<meta http-equiv="Pragma" content="no-cache">

上述方法在大多数浏览器中都适用。但如果用户设置了强制缓存或某些特殊的浏览器行为,浏览器仍会缓存内容。

更严格的控制需要服务器端配合,在服务器配置中设置相应的HTTP响应头,如在Apache、Nginx等服务器的配置文件中设置Cache-ControlExpires头部。

2、在HTML的head标签中,添加资源版本号。当引入 CSS 和 JavaScript 文件时,让每次文件内容有所改动,从而避免浏览器缓存问题。

<link rel="stylesheet" href="main.css?v=1.0" rel="external nofollow" >
<script src="main.js?v=1.0"></script>

3、如果是使用Webpack构建打包,在配置文件中利用其文件命名特性来为输出的文件添加hash。

// mini-css-extract-plugin 是一个 Webpack 插件,用于将 CSS 从 JavaScript bundle 中分离出来,生成独立的 CSS 文件。
// 这样做有利于提高网页加载速度,因为 CSS 可以被浏览器并行下载,而且还能利用浏览器对静态资源的缓存机制。
// 此外,它也支持 CSS Modules 和热模块替换(HMR)。
const MiniCssExtractPlugin = require('mini-css-extract-plugin');

module.exports = {
  // ...
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: '[name].[chunkhash].js', // 使用chunkhash为chunk生成哈希文件名
    chunkFilename: '[name].[chunkhash].chunk.js',
  },
  module: {
    rules: [
      {
        test: /\.css$/,
        use: [
          // 将MiniCssExtractPlugin.loader放在第一位,以将CSS提取到单独的文件中
          MiniCssExtractPlugin.loader,
          'css-loader',
        ],
      },
      // 如果你也在处理其他样式文件,如less或sass,也应相应配置
    ],
  },
  plugins: [
    // 在plugins部分配置MiniCssExtractPlugin
    new MiniCssExtractPlugin({
      filename: '[name].[contenthash].css',
      chunkFilename: '[id].[contenthash].chunk.css',
    }),
  ],
  // ...
};

若为vue项目,通过vue.config.js配置

const path = require('path')
const webpack = require('webpack')

module.exports = {
  publicPath: './',
  // 打包的时候使用hash值
  filenameHashing: true,
 
  // 输出文件目录
  outputDir: 'dist',
  
  configureWebpack: {
    // 打包编译后的js文件
    output: {
      filename: `js/[name].[chunkhash].js`,
      chunkFilename: `js/[name].[chunkhash].chunk.js`,
    }
  },
 
  // 打包后css文件
  css: {
    extract: { 
      filename: `css/[name].[contenthash].css`,
      chunkFilename: `css/[id].[contenthash].chunk.css`,
    }
  }
}

这样配置之后,每次打包发布后就不需要手动清除浏览器缓存了。

总结

到此这篇关于前端项目打包部署后如何避免让用户强制去清除浏览器缓存的文章就介绍到这了,更多相关前端打包部署清除浏览器缓存内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • JS中apply()的应用实例分析

    JS中apply()的应用实例分析

    这篇文章主要介绍了JS中apply()的应用,结合实例形式分析了apply()操作数组的相关使用技巧,需要的朋友可以参考下
    2019-06-06
  • 原生javascript AJAX 三级联动的实现代码

    原生javascript AJAX 三级联动的实现代码

    这篇文章主要介绍了原生javascript AJAX 三级联动的实现代码,非常不错代码简单易懂,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-05-05
  • 一文总结JavaScript中常见的设计模式

    一文总结JavaScript中常见的设计模式

    在程序设计中有很多实用的设计模式,而其中大部分语言的实现都是基于“类”。在程序设计中有很多实用的设计模式,而其中大部分语言的实现都是基于“类”。,本文将总结了JavaScript中常见的十五种设计模式,感兴趣的朋友可以参考下
    2023-05-05
  • uniapp实现全局设置字体大小(小中大的字体切换)

    uniapp实现全局设置字体大小(小中大的字体切换)

    随着UniApp的流行,越来越多的开发者选择使用它来构建跨平台应用程序,下面这篇文章主要给大家介绍了关于uniapp实现全局设置字体大小(小中大的字体切换)的相关资料,需要的朋友可以参考下
    2023-06-06
  • javascript学习笔记(七)利用javascript来创建和存储cookie

    javascript学习笔记(七)利用javascript来创建和存储cookie

    今天把javascript如何用来创建及存储cookie复习了一下,其中的一点体会拿出来和大家讨论,恳请高手指点一二。
    2011-04-04
  • JS调用某段SQL语句的方法

    JS调用某段SQL语句的方法

    这篇文章主要为大家详细介绍了通过JS调用某段SQL语句的相关方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • IE下js调试工具Companion.JS

    IE下js调试工具Companion.JS

    做web开发的朋友都清楚,js程序的调试是相当郁闷的,因为首先这种语言语法比较灵活,它是一种弱类型的脚本语言,很多错误是无法控制的。
    2010-10-10
  • js 自带的 map() 方法全面了解

    js 自带的 map() 方法全面了解

    下面小编就为大家带来一篇js 自带的 map() 方法全面了解。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • JS实现悬浮球只在一侧滑动并且是横屏状态下

    JS实现悬浮球只在一侧滑动并且是横屏状态下

    这篇文章主要介绍了JS实现悬浮球只在一侧滑动 并且是横屏状态下,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • CountUp.js数字滚动插件使用方法详解

    CountUp.js数字滚动插件使用方法详解

    这篇文章主要为大家详细介绍了CountUp.js数字滚动插件的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10

最新评论