我正在将一个库与 rollup 捆绑在一起,并尝试将 package.json 中的一个版本添加到代码本身中。
rollup 配置的相关位:
import pkg from './package.json'
output: [{
footer: `foo.version = '${pkg.version}'`
}]
问题是,它没有通过 hotreload/watch 更新。 (rollup -w -c rollup.development.config.js')
尝试了几件事:
- 使用输出插件:它们不会在手表上再次运行
- 在页脚中进行动态导入:也不再运行
- 包含 package.json 的自定义观察程序插件:这会触发重新加载,但仍不会运行将读取更新的 value 的代码(插件或页脚)
有没有办法做到这一点?我不介意在 package.json 更改时进行完全重建,但我想避免手动重新启动该过程。坦率地说,我很困惑这么简单的事情怎么会这么复杂。谢谢
编辑:即使我这样做,版本也不会更新:
const getVersion = () => ({
async renderStart () {
const data = await import('./package.json')
console.log('version: ' + data.version)
}
})
export default async () => ({
output: [{
plugins: [getVersion()]
}]
})
认为它是一个缓存,所以我尝试使用 ?date=' + Date.now() 使其无效,但这只会给我错误:找不到模块 './package.json?test=1652969298057'。似乎 rollup 正在使用 require :(
回答1
弄清楚了:
rollup.config.js
import glob from 'glob'
import path from 'path'
import fs from 'fs'
const watcher = (globs) => ({
buildStart () {
for (const item of globs) {
glob.sync(path.resolve(item)).forEach((filename) => { this.addWatchFile(filename) })
}
}
})
const updateVersion = () => ({
renderStart (outputOptions, inputOptions) {
outputOptions.footer = () => `cpexPackage.version = ' + ${JSON.parse(fs.readFileSync('package.json', 'utf8')).version}'`
}
})
export default {
plugins: [
watcher(['package.json'])
],
output: [{
plugins: [
updateVersion()
]
}]
}