Skip to content

Webpack 如何区分环境?

有些时候,我们需要针对生产环境和开发环境分别书写 webpack 配置。

为了更好的适应这种要求,webpack 允许配置不仅可以是一个对象,还可以是一个函数。

JavaScript
module.exports = (env) => {
  return {
    //配置内容
  };
};

在开始构建时,webpack 如果发现配置是一个函数,会调用该函数,将函数返回的对象作为配置内容,因此,开发者可以根据不同的环境返回不同的对象。

在调用 webpack 函数时,webpack 会向函数传入一个参数 env,该参数的值来自于 webpack 命令中给 env 指定的值,例如:

JavaScript
npx webpack --env abc # env: "abc"

npx webpack --env.abc # env: {abc:true}
npx webpack --env.abc=1  # env: {abc:1}
npx webpack --env.abc=1 --env.bcd=2 # env: {abc:1, bcd:2}

这样一来,我们就可以在命令中指定环境,在代码中进行判断,根据环境返回不同的配置结果。