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
*/
相关推荐
NEXT068 小时前
AI 应用工程化实战:使用 LangChain.js 编排 DeepSeek 复杂工作流
前端·javascript·langchain
念风零壹8 小时前
AI 时代的前端技术:从系统编程到 JavaScript/TypeScript
前端·ai
光影少年9 小时前
react的hooks防抖和节流是怎样做的
前端·javascript·react.js
小毛驴8509 小时前
Vue 路由示例
前端·javascript·vue.js
发现一只大呆瓜9 小时前
AI流式交互:SSE与WebSocket技术选型
前端·javascript·面试
m0_7190841110 小时前
React笔记张天禹
前端·笔记·react.js
Ziky学习记录10 小时前
从零到实战:React Router 学习与总结
前端·学习·react.js
wuhen_n10 小时前
JavaScript链表与双向链表实现:理解数组与链表的差异
前端·javascript
wuhen_n10 小时前
JavaScript数据结构深度解析:栈、队列与树的实现与应用
前端·javascript
狗哥哥11 小时前
微前端路由设计方案 & 子应用管理保活
前端·架构