美文网首页
解决js缓存的问题

解决js缓存的问题

作者: xiesen | 来源:发表于2022-11-23 16:32 被阅读0次

问题描述

大家用vue脚手架搭建前端工程时,常被缓存问题所困扰,具体的表现就是,当程序版本升级时,用户因为缓存访问的还是老的页面,然后很多同学很暴力的直接在index.html中加入了这几行代码:

<meta http-equiv="Expires" content="0">
<meta http-equiv="Pragma" content="no-cache">
<meta http-equiv="Cache-control" content="no-cache">
<meta http-equiv="Cache" content="no-cache">

升级时缓存问题倒解决了,但直接导致了用户每次访问你的程序时都要重新请求服务器,所有的静态资源都无法用缓存了,浪费流量,网络压力变大。

需求澄清

我们真正需要解决的问题,不是单纯的要缓存或者不要缓存,而是期望视情况而定:

程序每次升级后,用户都不会因为缓存问题而执行的仍然是老的程序。
若程序没升级,用户对静态资源的请求则能用到缓存。

解决原理

由于vue脚手架每次打包时,都会将打出的静态资源文件名加个哈希后缀,且index.html中引入时也加了对应的哈希后缀,所以每个版本的静态资源都是全新的,不用担心因升级导致的缓存问题。那么只需让index.html不缓存,且让其他静态资源缓存,就能实现要求。
让静态资源有缓存好办,问题在于怎么只让index.html不缓存。这里我们已经不能单单靠前端代码来实现了,需要用到服务器配置。通过服务器配置,来单独设置请求index.html时的header,以达到控制缓存的目的。

具体实现

在vue.config.js中配置(没有就创建vue.config.js文件)

// vue.config.js
if (process.env.UNI_PLATFORM === 'h5') {
    // 由于这种方式的打包,会导致编译生成微信小程序(只验证了微信小程序)无法正常使用,所以必须分开
    let filePath = 'static/js/'
    let Timestamp = new Date().getTime()
    module.exports = {
        // ... webpack 相关配置
        filenameHashing: false,
        configureWebpack: { // webpack 配置 解决js缓存的问题,目前只适配H5端打包
            output: { // 输出重构  打包编译后的 文件目录 文件名称 【模块名称.时间戳】
                filename: `${filePath}[name].js?v=${Timestamp}`,
                chunkFilename: `${filePath}[name].js?v=${Timestamp}`
            },
        }
    }
}else{
    // 其他打包需要的相关配置
    module.exports = {
        // ... webpack 相关配置
        filenameHashing: false
    }
}

相关文章

  • 解决js缓存的问题

    问题描述 大家用vue脚手架搭建前端工程时,常被缓存问题所困扰,具体的表现就是,当程序版本升级时,用户因为缓存访问...

  • 浏览器缓存?优点?清除方法?

    ☆前端优化:浏览器缓存技术介绍 - 简书 浏览器缓存(适用于前端解决缓存问题) - 简书 js清除浏览器缓存问题的...

  • spring mvc

    解决配置js/css/img缓存问题 spring.resources.chain.strategy.conten...

  • TagHelper 属性 asp-append-version

    为静态文件提供唯一版本号,来解决缓存问题,如https://localhost/js/site.js?v=1 。 ...

  • css、js文件缓存问题

    问题:浏览器为了提升用户体验,会将css、js文件缓存下来 解决: 在css、js文件后面添加版本号 =>

  • 解决js、css数据缓存问题

    在现实工作中,因为手上上线的项目很多,平且会经常修改,这样每次更改之后就会存在缓存问题,一般需要强刷才能解决缓存问...

  • JS缓存问题

    最近在javaweb前端的开发中,修改了一个公共的extJs.js文件,线上更新后导致很多用户反馈问题。看了半天,...

  • 缓存常见问题

    阿里一面:关于【缓存穿透、缓存击穿、缓存雪崩、热点数据失效】问题的解决方案 缓存穿透 缓存击穿 缓存雪崩

  • iOS webview 清除js缓存

    webview清除缓存不能清除js缓存 问题: uiwebview加载的是本地的html 文件(包含 HTML j...

  • 引用js\css时,解决静态缓存问题

    闲话不多说,上代码: 无非就是在引用css、js文件时,在后面加上了一个 version。当然,加上时间参数也是比...

网友评论

      本文标题:解决js缓存的问题

      本文链接:https://www.haomeiwen.com/subject/fpfwxdtx.html