前端打包版本号自增

1.新建sysInfo.json文件

perl 复制代码
{
	"version": "20240307@1.0.1"
}

2.新建addVersion.js文件,打包时执行,将版本号写入sysInfo.json文件

ini 复制代码
//npm run build打包前执行此段代码
let fs = require('fs')

//返回package的json数据
function getPackageJson() {
  let data = fs.readFileSync('./src/assets/json/sysInfo.json') //fs读取文件
  return JSON.parse(data) //转换为json对象
}

let packageData = getPackageJson() //获取package的json
let arr = packageData.version.split('@') //切割后的版本号数组
let date = new Date()
const year = date.getFullYear()
let month = date.getMonth() + 1
let day = date.getDate()
month = month > 9 ? month : '0' + month
day = day < 10 ? '0' + day : day
let today = `${year}${month}${day}`
let verarr = arr[1].split('.')
verarr[2] = parseInt(verarr[2]) + 1
packageData.version = today + '@' + verarr.join('.') //转换为以"."分割的字符串
//用packageData覆盖package.json内容
fs.writeFile('./src/assets/json/sysInfo.json', JSON.stringify(packageData, null, '\t'), err => {
  console.log(err)
})

3.package.json中配置

json 复制代码
  "scripts": {
    "dev": "vite",
    "serve": "vite",
    "build": "node ./src/addVersion.js && vite build",
    ....

4.使用

javascript 复制代码
import sysInfo from '@/assets/json/sysInfo.json'
相关推荐
Hyyy9 小时前
普通前端续命周报——第1周
前端·javascript
KaMeidebaby9 小时前
卡梅德生物技术快报|抗独特型抗体开发:半抗原检测技术瓶颈拆解,抗独特型抗体开发工程化实践
前端·数据库·人工智能·其他·百度·新浪微博
2501_940041749 小时前
纯前端创意交互:五款全新实用工具与视觉应用生成指南
前端·交互
刀法如飞9 小时前
《道德经》简单解说版-第 2 章:天下皆知美之为美
前端·后端·面试
发现一只大呆瓜11 小时前
超全 Vite 性能优化指南:网络、资源、预渲染三维落地方案
前端·面试·vite
IT_陈寒12 小时前
Vue的computed属性怎么突然不更新了?
前端·人工智能·后端
智商不够_熬夜来凑12 小时前
【Picker】单选多选
前端·javascript·vue.js
米饭不加菜12 小时前
Typora 原生流程图语法完全指南(Flowchart.js)
前端·javascript·流程图
scan72412 小时前
langgraphy条件边
前端·javascript·html
冰小忆13 小时前
类变量在继承场景下的初始化规则是怎样的?
java·前端·数据库