一篇文章解决Webpack

一:什么是webpack

webpack是一个用于现代JavaScript应用程序的静态模块打包工具。本质是一个软件包,

静态模块包括以下:html、css、js、图片等固定内容的文件

二:webpack工作原理

当 webpack 处理应用程序时,它会在内部从一个或多个入口点构建一个 依赖图(dependency graph),然后将你项目中所需的每一个模块组合成一个或多个 bundles,它们均为静态资源,用于展示你的内容。

所谓依赖图:当一个文件依赖另一个文件时,webpack都将文件视为直接存在依赖关系。

三:webpack使用流程

  1. 新建并初始化项目,编写业务源代码
  2. 下载webpack webpack-cli到当前项目中(本地软件包),并配置局部自定义命令(webpack源码会自动下载到node_modules中)
  3. 运行打包命令,自动产生dist分发文件夹(压缩和优化后,用于最终运行的代码)

四:打包入口起点(打包文件的主入口)

1单个入口语法

javascript 复制代码
module.exports={
	entry:{
		main:'输出路径'
	}
}
//简写形式如下:
module.exports={
	entry:'输出路径'
}

2 对象语法

五:打包出口(写入编译软件)

通过output选项,告知webpack如何向硬盘中写入编译文件。

注意,即使可以存在多个entry起点,但只能指定一个output配置。

1 用法

在output选项中,配置filename属性。用于规定输出的文件名配置

javascript 复制代码
module.exports={
	output:{
		filename:'bundle.js(输出规定的文件名)'
	}
}

2 多个入口起点

六:利用Webpack处理css代码

1 打包CSS代码

  1. 将css引入js入口文件(默认src/login/index.js)中
  2. 下载css.loader(解析css代码)和style.loader(把解析后的css代码插入到DOM中)本地软件包
  3. 配置webpack.config.js让Webpack拥有该加载器功能
  4. 打包后观察结果

2 提取CSS代码

1 为什么要提取css代码为一个独立文件

浏览器可以缓存css文件,同时下载css与js文件,提高网页运行效率

2 如何使用mini-css-extract-plugin插件

  1. 下载mini-css-extract-plugin本地软件包
  2. 配置webpack.config.js让Webpack拥有插件功能
  3. 打包后观察结果

七:搭建开发环境

配置webpack-dev-server快速开发应用程序

作用:启动web服务,自动检测代码变化,热更新到网页

注意:dist目录和打包内容是在内存里

相关推荐
天若有情673几秒前
前端HTML精讲01:别再乱 div 一把抓,吃透语义化标签才是进阶第一步
前端·html
Highcharts.js1 分钟前
React 开发者的图表库生态:Highcharts React
前端·react.js·前端框架
阿部多瑞 ABU1 分钟前
文明文化悖论
前端·人工智能·ai写作
钛态20 分钟前
Flutter 三方库 react 泛前端核心范式框架鸿蒙原生层生态级双向超能适配:跨时空重塑响应式单向数据流拓扑与高度精密生命周期树引擎解耦视图渲染控制中枢(适配鸿蒙 HarmonyOS ohos)
前端·flutter·react.js
全栈前端老曹21 分钟前
【前端地图】地图开发基础概念——地图服务类型(矢量图、卫星图、地形图)、WGS84 / GCJ-02 / BD09 坐标系、地图 SDK 简介
前端·javascript·地图·wgs84·gcj-02·bd09·地图sdk
只与明月听22 分钟前
RAG深入学习之向量数据库
前端·人工智能·python
吕不说44 分钟前
AI 面试总挂?可能是表达出了问题:三层表达法 + STAR 进阶框架
前端
社恐的下水道蟑螂1 小时前
LangChain 进阶实战:从玩具 Demo 到生产级 AI 应用(JS/TS 全栈版)
前端·langchain·openai
Fairy要carry1 小时前
项目01-手搓Agent之loop
前端·javascript·python
亲亲小宝宝鸭1 小时前
Ctrl ACV工程师的提效之路:删掉项目中的冗余
前端