一个十分简单的关于生产环境和开发环境的webpack配置

Posted 码疯

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了一个十分简单的关于生产环境和开发环境的webpack配置相关的知识,希望对你有一定的参考价值。

webpack-dev-server更新后自带express服务器,已经不需要自己搭建。vue-cli从17年底左右也换成了最新的webpack-dev-server,而不是用webpack-dev-middleware

---------------------------------------------------------- 分割线 ----------------------------------------------------------

开发环境生产环境的构建目标差异很大。

开发环境中,我们需要具有强大的、具有实时重新加载(live reloading)或热模块替换(hot module replacement)能力的 source map 和 localhost server。

而在生产环境中,我们的目标则转向于关注更小的 bundle,更轻量的 source map,以及更优化的资源,以改善加载时间。

由于要遵循逻辑分离,我们通常建议为每个环境编写彼此独立的 webpack 配置。

然后在相应的环境配置中使用  webpack-merge  将公共js合并进来。

 

我所了解到的配置思路,有两种:

方法一: 使用webpack-dev-server配置开发环境(这个简洁一些);

方法二: 使用webpack-dev-middleware 和 webpack-hot-middleware配置开发环境;( 应该是我们经常用到的,因为vue-cli就是用的这个 );

第一种方法可直接参考这个webpack官方文档

 

先看看项目结构

 

方法二:

使用webpack-dev-middleware 和 webpack-hot-middleware手动配置自动刷新和热重载。也就需要用node来启动;

因为本身webpack-dev-server就是通过这两个node中间件加上express实现的。这个可自行百度验证。

 

我们通过执行过程来看这个是怎么搭建的。

启动命令:

  "scripts": {
    "dev": "set NODE_ENV=development&& node build/webpack-env.js",
    "build": "set NODE_ENV=prodction&& node build/webpack-env.js"
  },

  不同命令下设置的环境变量不同(这里的NODE_ENV,在webpack-env.js中通过process.env.NODE_ENV访问);

       注意: liunx和mac下使用  export  而不是 set;

来到了我的入口文件里面:

var path = require(\'path\');
var webpack = require(\'webpack\');
var app = require(\'express\')();
var devConfig = require(\'./webpack.dev.js\');  //导入开发环境配置
var prodConfig = require(\'./webpack.prod.js\');   //导入生产环境配置

var compiler = webpack(devConfig);
var env = process.env.NODE_ENV;  //获取我们在package.json里面设置的环境变量
var port = \'8000\';

(function() {
  //生产环境
  if (env == \'prodction\') {
//如果是生产环境,直接打包,然后退出这个匿名函数,否则执行开发环境逻辑 webpack(prodConfig, function(err, status) { if (err) throw err; }); return; } //开发环境 //设置‘webpack.common.js’的入口配置 Object.keys(devConfig.entry).forEach(function(key) {
//这里的reload=true,作用就是页面自动刷新 devConfig.entry[key] = [\'webpack-hot-middleware/client?reload=true\'].concat(devConfig.entry[key]); }) var devMiddleware = require(\'webpack-dev-middleware\')(compiler, { stats: { colors: true, //设置日志颜色 } }); var hotMiddleware = require(\'webpack-hot-middleware\')(compiler); app.use(devMiddleware); app.use(hotMiddleware); //首次编译后的回调函数 devMiddleware.waitUntilValid(function() { console.log("listen at localhost:" + port); //自动打开浏览器 require(\'opn\')(\'http://localhost:\' + port); }); app.listen(port); })();

 

如果是开发环境,执行webpack-dev.js:

const Merge = require(\'webpack-merge\');
const webpack = require(\'webpack\');
const CommonConfig = require(\'./webpack.base.js\');  //导入公共基础配置

//使用“webpack-merge”将公共配置和生产配置合并 module.exports = Merge(CommonConfig, { plugins: [ new webpack.HotModuleReplacementPlugin(), ] })

我在这个生产环境下添加了一个它独有的  热重载时所需的插件,可以在这个基础上添加更多。

 

如果是生产环境,执行webpack-prod.js:

const Merge = require(\'webpack-merge\');
const webpack = require(\'webpack\');
const CommonConfig = require(\'./webpack.base.js\');

module.exports = Merge(CommonConfig, {
  plugins: [
    new webpack.LoaderOptionsPlugin({
      minimize: true,
      debug: false
    }),
    new webpack.DefinePlugin({
      //打包过后会将index.js等文件内的 ‘process.env.NODE_ENV’ 替换为 ‘production’
      \'process.env\': {
        \'NODE_ENV\': JSON.stringify(\'production\')
      }
    }),
    new webpack.optimize.UglifyJsPlugin({
      beautify: false,
      mangle: {
        screw_ie8: true,
        keep_fnames: true
      },
      compress: {
        screw_ie8: true
      },
      comments: false
    })
  ]
})

这个也是同理。

 

环境环境变量可以用专门的文件来设置,而不用设置到package.json。但是比较懒。。。

这个主要体现生产和开发是如何分离的。一些我们常用的熟悉的loader以及插件,都可以在这个基础上添加。所以我就不过多阐述。

 

项目地址:https://github.com/liyang0612/light-complete-webpack

以上是关于一个十分简单的关于生产环境和开发环境的webpack配置的主要内容,如果未能解决你的问题,请参考以下文章

十分钟完成Springboot 生产环境搭建代码仓库安装自动打包部署(密码登录)

如何 在Docker窗口中部署PHP开发环境

ASP .NET CORE 根据环境变量支持多个 appsettings.json

[Dubbo开发]配置简单的生产者和消费者

vue生产环境图片无法显示200

十分钟完成Springboot 生产环境搭建代码仓库安装自动打包部署(密码登录)