使用koa起webpack服务的时候 如何控制webpack打包完成后再执行中间键方法

发布于 2022-09-11 20:56:45 字数 1331 浏览 17 评论 0

  • 在往koa全局ctx.state挂在ver.json的时候 webpack中哈希版本文件还没有生成
  • 怎么控制执行顺序
// json plugin
const fs = require('fs');
const path = require('path');

class BuildEndPlugin {
    constructor(props) {
        this.filename = props.filename;
    }
    fn(compilation) {
        const currentPath = path.resolve(__dirname, `../public/${this.filename}`);
        const chunkName = {};
        const chunkObj = compilation.chunks;
        chunkObj.forEach(item => {
            Object.assign(chunkName, {
                [item.name]: item.hash
            });
        });
        if (!fs.existsSync(currentPath)) {
            fs.mkdir(`public/version`, () => {
                fs.writeFile(currentPath, JSON.stringify(chunkName));
            });
        }
        fs.writeFile(currentPath, JSON.stringify(chunkName));
    }
    apply(compiler) {
        const afterEmit = (compilation, cb) => {
            this.fn(compilation);
            cb();
        }
        compiler.plugin('after-emit', afterEmit);
    }
}

module.exports = BuildEndPlugin;
// app.js 挂载

app.use(async (ctx, next) => {
  Object.assign(ctx.state, {
    version
  });
  await next();
});
// webpack new 插件
new CreateJsonPlugin({
  filename: 'version/dev-ver.json'
}),

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

┈┾☆殇 2022-09-18 20:56:45

重启电脑试试?

雅心素梦 2022-09-18 20:56:45
await new Promise((res) => {
    setTimeout(() => {
      res();
    }, 0);
  });

放在挂在hash前面
弟弟回答

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文