10

我正在尝试使用 esbuild 在 npm 项目中捆绑和缩小我的文件。它正在最小化我传入的每个文件,但它不是捆绑。当有多个文件时,它给了我必须使用“outdir”的错误。但是,这让我将所有这些文件最小化到一个文件夹中。这不是我想要的行为,也不是捆绑。我只希望它获取所有这些文件并将它们合并为一个。

let {build} = require("esbuild");
let files = ["file1.js", "file2.js"];

build({
    entryPoints: files,
    outdir: "./views/dashboardPage/bundle",
    minify: true,
    bundle: true
}).catch(() => process.exit(1));

我已将 bundle 设置为 true,但它仍然要求我使用 outdir,它只是将这些文件最小化返回给我。他们基本上有 0 个关于此的文档,并且每篇关于它的在线帖子都只是从 GitHub 复制/粘贴自述文件。我怎样才能使它捆绑?

4

3 回答 3

7

每个入口点文件将成为一个单独的包。每个包都包含入口点文件和它导入的所有文件。通过两个入口点将创建两个单独的包。捆绑过程与文件串联不同。

如果您想要一个包中的所有文件,您可以从一个文件中引用它们并将该文件用作入口点:

import "./file1.js"
import "./file2.js"

使用 esbuild 执行此操作可能如下所示:

let {build} = require("esbuild");
let files = ["./file1.js", "./file2.js"];

build({
    stdin: { contents: files.map(f => `import "${f}"`).join('\n') },
    outfile: "./views/dashboardPage/bundle.js",
    minify: true,
    bundle: true
}).catch(() => process.exit(1));
于 2020-07-25T22:44:35.433 回答
5

您可以使用inject选项(https://esbuild.github.io/api/#inject),例如,

const options = {
  entryPoints: ['index.js'],
  inject: ['file1.js', ..., 'fileN.js'],
  bundle: true,
  minify: true,
  sourcemap: true,
  outdir: path,
};
esbuild.buildSync(options);
于 2021-06-11T01:38:21.847 回答
0

根据 Alexander 的回复,我终于找到了将整个文件夹打包到单个文件中的解决方案:

const esbuild = require('esbuild');
const glob = require('glob');

esbuild
    .build({
        stdin: { contents: '' },
        inject: glob.sync('src/js/**/*.js'),
        bundle: true,
        sourcemap: true,
        minify: true,
        outfile: 'web/js/bundle.js',
    })
    .then(() => console.log("⚡ Javascript build complete! ⚡"))
    .catch(() => process.exit(1))
于 2022-03-03T09:54:16.987 回答