一篇文章解决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目录和打包内容是在内存里

相关推荐
灰灰勇闯IT24 分钟前
Flutter for OpenHarmony:布局组件实战指南
前端·javascript·flutter
⑩-1 小时前
Vue框架学习
前端·vue.js·学习
a程序小傲1 小时前
京东Java面试被问:基于Gossip协议的最终一致性实现和收敛时间
java·开发语言·前端·数据库·python·面试·状态模式
小二·1 小时前
Python Web 开发进阶实战:AI 原生应用商店 —— 在 Flask + Vue 中构建模型即服务(MaaS)与智能体分发平台
前端·人工智能·python
Devlive 开源社区1 小时前
技术日报|推理RAG文档索引PageIndex登顶日增1374星,React视频工具Remotion二连冠进前二
前端·react.js·前端框架
xkxnq1 小时前
第三阶段:Vue 路由与状态管理(第 45 天)(路由与状态管理实战:开发一个带登录权限的单页应用)
前端·javascript·vue.js
方方洛1 小时前
技术实践总结:schema-bridgion:json、xml、yaml、toml文件相互转换
xml·前端·typescript·node.js·json
object not found2 小时前
基于uniapp开发小程序自定义顶部导航栏状态栏标题栏
前端·javascript·小程序·uni-app
We་ct2 小时前
LeetCode 28. 找出字符串中第一个匹配项的下标:两种实现与深度解析
前端·算法·leetcode·typescript
xzl042 小时前
小智服务端chat入口工具调用流程
java·服务器·前端