vue项目版本更新后文件存在缓存问题解决方案(vue-cli2.0/vue-cli3.0)

vue-cli2.0

1.配置webpack.prod.conf.js 

 配置output加t=[chunkhash:8]相当于加时间戳,用于清缓存

output: {
    path: config.build.assetsRoot,
    filename: utils.assetsPath('js/[name].[chunkhash].js?t=[chunkhash:8]'),
    chunkFilename: utils.assetsPath('js/[id].[chunkhash].js?t=[chunkhash:8]')
  },

2.在static静态目录下新建version.json每次发版更改里面的版本号 

{
    "version": "0.0.1"
}

3.在src中新建 libs/versionUpdate.js文件

import Vue from 'vue';

const vm = new Vue();
const isNewVersion = () => {
  let url = `//${ window.location.host }/static/version.json`;
  vm.$get(url).then(res => {
    let version = res.data.version;
    let localVersion = localStorage.getItem('version');
    if (localVersion && localVersion != version) {
      if (confirm("系统检测到有新版本,是否更新?")) {
        localStorage.setItem('version', res.data.version);
        window.location.reload();
        return;
      }
    }else {
      localStorage.setItem('version', res.data.version);
    }
  });
};
export default {
  isNewVersion
}

4.在全局路由拦截中写,只要每次版本号不同就重新加载页面配合第一步就可以清楚浏览器缓存

import versionTood from '@/libs/versionUpdate'

router.beforeEach(( to, from, next ) => {
  //判断当前代码版本是否与服务器中代码版本一致,如不一致则刷新页面获取最新
  versionTood.isNewVersion();
}

 

vue-cli3.0

1.在vue.config.js中配置output

const Timestamp = new Date().getTime();

configureWebpack: {
    output: {
      filename: `js/[name].${Timestamp}.js`, // 每次构建打包时给文件名加上时间戳,确保每次版本更新的文件名不一样
      chunkFilename: `js/[name].${Timestamp}.js`
    }
}

2.在public目录下新建version.json每次发版更改里面的版本号 (同vue-cli2.0) 

3.在src中新建 libs/versionUpdate.js文件

import Vue from 'vue';
import { axios } from '@/utils/request'
const vm = new Vue();
const isNewVersion = () => {
  let url = `//${ window.location.host }/version.json`;
  axios.get(url).then(res => {
    //同vue-cli2.0
     .......
  });
};
export default {
  isNewVersion
}

4.在全局路由拦截中写,只要每次版本号不同就重新加载页面配合第一步就可以清楚浏览器缓存 (同vue-cli2.0) 

 

 

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章