webpack基础配置

entry

1.入口文件,单独入口为字符串形式,多个入口文件为数组形式

output

1.出口文件,在这里设置path和fileName

mode

1.判断是用于生产环境的配置还是开发环境的配置,devlepment,production

module---loader

1.由英文翻译过来为模块,在这里主要是在rules里面配置loader,loader的执行顺序由下往上,由后往前的执行顺序,而loader的写法又有两种

  • 当只有一种loader的时候为字符串形式
  • 当有多种且不需要额外配置时使用数组形式
  • 当有loader需要进行详细配置时则是对象形式里面增加一个options选项 2.常见loader有babel-loader,css-loader,less-loader,style-loader,url-loader,file-loader,postcss-loader(做css兼容性),eslint-loader,html-loader(实现在html使用js里面的变量)

plugin

1.常见plugin:HtmlWebpackPlugin,MiniCssExtractPlugin(提取css文件的插件),OptimizeCssAssetsWebpackPlugin(压缩css的插件)

webpack性能优化方案---devServer

1.启用热更新,devServe里面有一个hot设置为true就行

webpack性能优化方案---devtool

webpack性能优化方案---oneOf

1.此选项在module里面的rules里面,后跟一个数组,作用,使文件匹配到一个loader之后就不在往下继续进行匹配了,减少loader匹配次数

webpack性能优化方案---缓存

1.在babel-loader中开启缓存,设置cacheDirectory为true,在后续构建中直接读取缓存,不需要在重新构建

webpack性能优化方案---代码分割-optimization

1.只需要在optimization设置splitChunks里面的chunks为all

webpack性能优化方案---开启多进程打包

1.使用thread-loader来设置多进程打包

webpack性能优化方案---externals

1.配置externals选项

webpack性能优化方案---懒加载预加载

1.使用contenthash值进行打包

webpack性能优化方案---pwa

1.使用workBox,用WorkBoxWebpackPlugin插件生成一个serviceworker,此技术还可以实现联网正常访问项目

webpack性能优化方案---dll

1.告诉webpack哪些东西需要打包,哪些东西不需要打包,使用AddAssetHtmlWebpackPlugin这个插件,将某个文件打包输出出去,并在html自动引入该资源

webpack.dll.js

js 复制代码
/*
  使用dll技术,对某些库(第三方库:jquery、react、vue...)进行单独打包
    当你运行 webpack 时,默认查找 webpack.config.js 配置文件
    需求:需要运行 webpack.dll.js 文件
      --> webpack --config webpack.dll.js
*/
相关推荐
m0_5485147713 分钟前
前端Pako.js 压缩解压库 与 Java 的 zlib 压缩与解压 的互通实现
java·前端·javascript
AndrewPerfect14 分钟前
xss csrf怎么预防?
前端·xss·csrf
Calm55017 分钟前
Vue3:uv-upload图片上传
前端·vue.js
浮游本尊21 分钟前
Nginx配置:如何在一个域名下运行两个网站
前端·javascript
m0_7482398322 分钟前
前端bug调试
前端·bug
m0_7482329224 分钟前
[项目][boost搜索引擎#4] cpp-httplib使用 log.hpp 前端 测试及总结
前端·搜索引擎
新中地GIS开发老师29 分钟前
《Vue进阶教程》(12)ref的实现详细教程
前端·javascript·vue.js·arcgis·前端框架·地理信息科学·地信
m0_7482495432 分钟前
前端:base64的作用
前端
html组态38 分钟前
web组态可视化编辑器
前端·物联网·编辑器·web组态·组态·组态软件
~央千澈~1 小时前
如果你的网站是h5网站,如何将h5网站变成小程序-除开完整重做方法如何快速h5转小程序-h5网站转小程序的办法-优雅草央千澈
前端·apache