最近有在开发钉钉h5微应用程序,坑爹的钉钉h5即使打包js做了hash串 每次打包上线依然会读取缓存。要手动清除掉手机里应用的缓存信息才可以读取最新的代码,这么做的话 用户体验着实太糟糕了。
百度了下说是在入口引用js后面加上版本号就能不读取缓存,ok 那想办法每次打包去更新版本号就好了。

要每次去更新版本号,那必然要用到node的fs模块来读写文件,开搞:

所有的环境变量文件里声明一个版本号

h5内嵌ios调用方法 app嵌入h5缓存问题_缓存

根目录新建一个js文件update.version.js
引入文件操作模块和路径模块以及获取当前版本号

const fs = require('fs');
const path = require('path');

const version = process.env.VUE_APP_VERSION;

声明一个函数

function changeVersion() {
	// 执行函数
}

判断当前环境是正式环境执行更新版本号操作

function changeVersion() {
	if (process.env.NODE_ENV === 'production') {
	    const _v = version.split('.').map(Number);
	    // 确定版本号
	    if (_v[2] < 10) {
	      _v[2]++;
	    } else {
	      if (_v[1] < 10) {
	        _v[1]++;
	        _v[2] = 0;
	      } else {
	        _v[0]++;
	        _v[1] = 0;
	        _v[2] = 0;
	      }
	    }
	    // 修改版本号
	    // 同步读文件
	    const file = fs.readFileSync(
	      path.join(__dirname, '.env.production'),
	      'utf-8'
	    );
	    // 需要更新的数据 由于本人reg实在是太差 正则写不来orz
	    const V = `VUE_APP_VERSION = ${_v.join('.')}`;
	    // 当前的数据
	    const nowV = `VUE_APP_VERSION = ${version}`;
	    // 替换数据 正则大佬可以直接在这里配置修改 不需要单独声明变量来替换
	    const result = file.replace(nowV, V);
	    // 同步写文件
	    fs.writeFileSync(path.join(__dirname, '.env.production'), result, 'utf-8');
	    return _v.join('.');
	 } else {
	 	return version
	 }
 }

别忘了把该函数导出

module.exports = changeVersion;

这样我们就做到了更新版本号文件的功能,接下来拿导出的版本号放到js文件路径上;
在vue.config.js文件上:

const changeVersion = require('./update.version');

const version = changeVersion();

module.exports里的chainWebpack配置项上添加config.output.filename

chainWebpack: (config) => {
    // 是一个函数,会接收一个基于 webpack-chain 的 ChainableConfig 实例。允许对内部的 webpack 配置进行更细粒度的修改。
    config.resolve.alias
      .set('@', resolve('src')) // key,value自行定义,比如.set('@@', resolve('src/components'))
      .set('_c', resolve('src/components'));
    config.plugin('html').tap((args) => {
      args[0].title = '';
      return args;
    });
    // 给js添加hash和版本号
    config.output.filename(`[name].[hash].js?version=${version}`).end();
  },

现在就可以每次打包先调用nodejs修改版本文件并获取最新的版本号添加到入口文件上;

完美解决


突然发现公司是jenkins自动部署的,自动部署 意味着每次都是拉git最新的代码来安装打包,打包后并不会把更新的版本号push到git去啊,那它下次还是读取的旧版本号啊喂,,,,

该方法貌似只适合手动部署!!