webpack4系列教程(九):开发环境和生产环境
栏目: JavaScript · 发布时间: 5年前
内容简介:如果你一直跟随我前面的博文,那么你对webpack的基础知识已经有比较深刻的理解了。之前,我们一直执行着:来打包编译输出我们的代码,本文我们来看看如何构建一个开发环境,来使我们的开发变得方便些。webpack-dev-server是一个简单的小型的web服务器,并且能够实时重载,配置也很简单,首先安装:
1. 构建开发环境
如果你一直跟随我前面的博文,那么你对webpack的基础知识已经有比较深刻的理解了。之前,我们一直执行着:
npm run build
来打包编译输出我们的代码,本文我们来看看如何构建一个开发环境,来使我们的开发变得方便些。
1.1 webpack-dev-server
webpack-dev-server是一个简单的小型的web服务器,并且能够实时重载,配置也很简单,首先安装:
npm install --save-dev webpack-dev-server
配置webpack.config.js:
devServer: { port: 8080, // 端口号 host: '0.0.0.0', // 主机名,设为该值可通过IP访问 overlay: { errors: true // 错误提示 } }
在package.json中添加命令:
"dev": "cross-env NODE_ENV=development webpack-dev-server --config config/webpack.config.js"
执行:
npm run dev
可见我们的服务已经跑起来了:
1.2 source-map
在webpack打包源码时,我们会很难找到错误的出现位置,比如将源文件 sum.js、minus.js打包到bundle.js中,其中一个源文件出现了错误,仅仅会追踪到bundle.js中,这对我们来说并不理想。因此为了更加便捷的找到错误的原始位置,JavaScript为我们提供了 source-map的功能,将编译后的代码映射回原始源代码。如果一个错误来自于 sum.js,source map 就会明确的告诉你。
我们来测试一下,在sum.js中输出一个错误:
// ES Mudule 规范 export default function (a, b) { console.error('this is test') // 输出错误 return a + b }
在没有devtool配置的情况下 npm run dev,会发现错误提示的行数并不准确,
原因是我们的代码是被编译过的
然后在webpack.config.js中加入配置:
devtool: 'inline-source-map', // 加入devtool配置
当配置文件改动时需要重新执行 npm run dev:
错误提示行数以及源码映射都是正确的。devtool的取值有很多,大家可根据需要自行配置
1.3 模块热替换
模块热替换(Hot Module Replacement)是 webpack 提供的最有用的功能之一。它允许在运行时更新各种模块,而无需进行完全刷新。
使用非常简单,在webpack.config.js中引入webpack:
const webpack = require('webpack')
在plugins数组中添加:
new webpack.NamedModulesPlugin(), new webpack.HotModuleReplacementPlugin()
给devServer中的hot属性设为true:
devServer: { port: 8080, // 端口号 host: '0.0.0.0', // 主机名,设为该值可通过IP访问 overlay: { errors: true // 错误提示 }, hot: true }
这样我们修改代码的时候就可以局部刷新模块而不是刷新整个页面了。
2.构建生产环境
虽然,以上我们将生产环境和开发环境做了略微区分,但是,请注意,我们还是会遵循不重复原则(Don't repeat yourself - DRY),保留一个“通用”配置。为了将这些配置合并在一起,我们将使用一个名为 webpack-merge 的工具。通过“通用”配置,我们不必在环境特定的配置中重复代码。
我们先从安装 webpack-merge 开始,用来合并webpack配置项:
npm install --save-dev webpack-merge
在config文件夹下创建 webpack.dev.js 和 webpack.build.js 并修改 webpack.config.js,将开发与生产环境的公共配置放在webpack.config.js中:
const path = require('path') const HtmlWebpackPlugin = require('html-webpack-plugin') const MiniCssExtractPlugin = require('mini-css-extract-plugin') const isDev = process.env.NODE_ENV === 'development' const config = { entry: { main: path.join(__dirname, '../src/main.js') }, output: { filename: '[name].bundle.js', path: path.join(__dirname, '../dist') }, module: { rules: [ { test: /\.(vue|js|jsx)$/, loader: 'eslint-loader', exclude: /node_modules/, enforce: 'pre' }, { test: /\.js$/, loader: 'babel-loader', exclude: /node_modules/ }, { test: /\.vue$/, loader: 'vue-loader', options: createVueLoaderOptions(isDev) }, { test: /\.ejs$/, use: ['ejs-loader'] }, { test: /\.css$/, use: [ isDev ? 'vue-style-loader' : MiniCssExtractPlugin.loader, { loader: 'css-loader', options: { importLoaders: 1 } }, 'postcss-loader' ] }, { test: /\.less$/, use: [ isDev ? 'vue-style-loader' : MiniCssExtractPlugin.loader, 'css-loader', { loader: 'postcss-loader', options: { sourceMap: true } }, 'less-loader' ] }, { test: /\.(jpg|jpeg|png|gif|svg)$/, use: [ { loader: 'url-loader', options: { name: '[path][name]-[hash:5].[ext]', limit: 1024 } } ] } ] }, plugins: [ new HtmlWebpackPlugin({ template: path.join(__dirname, '../index.html'), inject: true, minify: { removeComments: true } }) ] } module.exports = config
webpack.dev.js
const merge = require('webpack-merge') const common = require('./webpack.config.js') module.exports = merge(common, { mode: 'development', devtool: 'inline-source-map', devServer: { port: 8080, host: '0.0.0.0', overlay: { errors: true }, historyApiFallback: { index: '/index.html' } } })
webpack.build.js
const path = require('path') const CleanWebpackPlugin = require('clean-webpack-plugin') const MiniCssExtractPlugin = require('mini-css-extract-plugin') const merge = require('webpack-merge') const common = require('./webpack.config.js') module.exports = merge(common, { mode: 'production', optimization: { splitChunks: { chunks: 'initial', automaticNameDelimiter: '.', cacheGroups: { commons: { name: 'commons', chunks: 'initial', minChunks: 2, priority: 3 }, vendors: { test: /[\\/]node_modules[\\/]/, priority: 1 } } }, runtimeChunk: { name: entrypoint => `manifest.${entrypoint.name}` } }, plugins: [ new MiniCssExtractPlugin({ filename: '[name].css' }), new CleanWebpackPlugin( ['dist'], { root: path.join(__dirname, '../') } ) ] })
修改package.json的命令:
"dev": "cross-env NODE_ENV=development webpack-dev-server --config config/webpack.dev.js", "build": "cross-env NODE_ENV=production webpack --config config/webpack.build.js --progress --inline --colors"
现在分别执行 npm run dev 和 npm run build 就会得到你想要的了。
本人才疏学浅,如有不当之处,欢迎批评指正
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 分离Webpack开发环境与生产环境的配置
- 重构之路:webpack区分生产环境和开发环境
- 生产环境使用Airflow
- RabbitMQ 生产环境配置详解
- MySQL生产环境级别部署
- Google 的全球生产环境架构
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Spring技术内幕
计文柯 / 机械工业出版社 / 2010-1-1 / 55.00元
内容简介: 本书是Spring领域的问鼎之作,由业界拥有10余年开发经验的资深Java专家亲自执笔!Java开发者社区和Spring开发者社区一致强烈推荐。 国内第一本基于Spring3.0的著作,从源代码的角度对Spring的内核和各个主要功能模块的架构、设计和实现原理进行了深入剖析。你不仅能从木书中参透Spring框架的优秀架构和设计思想,而且还能从Spring优雅的实现源码中一窥......一起来看看 《Spring技术内幕》 这本书的介绍吧!
HTML 压缩/解压工具
在线压缩/解压 HTML 代码
随机密码生成器
多种字符组合密码