前端打包版本号自增

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'
相关推荐
lvchaoq16 分钟前
页面停留时间过长导致token过期问题
前端
elangyipi12320 分钟前
深入理解前端项目中的 package.json 和 package-lock.json
前端·json
LYFlied33 分钟前
【算法解题模板】-【回溯】----“试错式”问题解决利器
前端·数据结构·算法·leetcode·面试·职场和发展
composurext33 分钟前
录音切片上传
前端·javascript·css
程序员小寒33 分钟前
前端高频面试题:深拷贝和浅拷贝的区别?
前端·javascript·面试
狮子座的男孩38 分钟前
html+css基础:07、css2的复合选择器_伪类选择器(概念、动态伪类、结构伪类(核心)、否定伪类、UI伪类、目标伪类、语言伪类)及伪元素选择器
前端·css·经验分享·html·伪类选择器·伪元素选择器·结构伪类
zhougl99639 分钟前
Vue 中的 `render` 函数
前端·javascript·vue.js
听风吟丶41 分钟前
Spring Boot 自动配置深度解析:原理、实战与源码追踪
前端·bootstrap·html
跟着珅聪学java41 分钟前
HTML中设置<select>下拉框默认值的详细教程
开发语言·前端·javascript
IT_陈寒42 分钟前
JavaScript 性能优化:5个被低估的V8引擎技巧让你的代码提速50%
前端·人工智能·后端