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
*/
相关推荐
_斯洛伐克19 分钟前
uniapp 知识点
前端·javascript·uni-app
木木与呆呆1 小时前
Chrome截取网页全屏
前端·chrome
向宇it2 小时前
fastadmin搜索刷新列表,怎么限制用户频繁点击?
开发语言·前端·javascript·fastadmin
Ylucius3 小时前
常见服务器大全----都是什么?又有何作用?区别联系是什么?---web,应用,数据库,文件,消息队列服务器,Tomat,Nginx,vite.....
java·前端·javascript·chrome·学习·node.js·express
alicca5 小时前
递归手撕,JSON 字符串化和解析,加权树结构的字符串解析对象,解析并返回DOM 树结构(DOMParser),解析带有层级的文本
前端·javascript
李是啥也不会5 小时前
JavaScript中的输出方式
开发语言·前端·javascript
炒毛豆5 小时前
ant design vue中带勾选表格报Tree missing follow keys: ‘undefined‘解决方法
前端·javascript·vue.js
大多_C5 小时前
python中logging的用法
前端·python
林某人的代码日常5 小时前
前端之render函数的理解
前端·vue.js·react.js
isea5337 小时前
如何只用 CSS 制作网格?
前端·css