前端开发深入了解webpack

news/2024/12/21 23:49:37/

什么是webpack

Webpack 是一个现代 JavaScript 应用程序的模块打包工具。它主要用于将各种资源(如 JavaScript、CSS、图片等)打包成一个或多个文件,以优化Web应用的加载性能。

Webpack 的核心功能包括:

  1. 模块化:支持将代码拆分为模块,便于管理和重用。
  2. 打包:将多个模块和资源打包成一个或多个文件,减少HTTP请求。
  3. 加载器(Loaders):处理不同类型的文件(如转换 ES6 到 ES5、编译 Sass 等)。
  4. 插件(Plugins):扩展功能,执行各种任务,例如代码压缩、环境变量管理等。
  5. 热模块替换:在开发过程中实时更新模块,提升开发效率。
     

webpack编译原理(构建流程)

  1. 初始化:读取配置文件(如webpack.config.js),初始化Compiler对象
  2. 构建模块:解析入口文件,找到所有依赖模块
  3. 编译模块:调用所有配置的loader对文件进行转换
  4. 生成依赖图:生成所有模块的AST(抽象语法树),并提取依赖关系,生成依赖图
  5. 完成编译模块并输出:根据entry配置(依赖图)生成代码块chunk(一个或多个打包文件)
  6. 输出完成:输出所有的chunk到指定目录
  7. 监听(可选):在开发模式下,Webpack 可以监视文件变化,自动重新构建和刷新浏览器

loader和plugin的区别

loader

  • 主要用于转换模块的内容
  • 在构建过程中将文件从一种格式转换为另一种格式(如将ES6转换为ES5)
  • 通过module.rules配置

plugin

  • 用于扩展Webpack的功能,执行更广泛的任务
  • 可以处理构建过程中的各种操作,如优化、压缩、生成文件等
  • 通过plugins数组配置

总结:Loader处理单个文件的转换,Plugin用于整体构建过程的扩展和优化

常用的loader和plugin

loader

  • babel-loader:将ES6/ES7代码转换为向后兼容的JavaScript
  • css-loader:解析CSS文件中的@import和url(),使其能够被Webpack处理
  • style-loader:将CSS插入到DOM中,通常与css-loader一起使用
  • file-loader:处理文件导入,生成文件并返回其URL
  • url-loader:类似于file-loader,但可以将小文件转换为Data URL
  • sass-loader:将Sass/SCSS文件编译为CSS
  • less-loader:将Less文件编译为CSS

plugin

  • HtmlWebpackPlugin:动态生成HTML文件,并自动引入Webpack打包的资源
  • MiniCssExtractPlugin:将CSS提取成单独的文件,而不是内联在JS中
  • CleanWebpackPlugin:在每次构建前清理输出目录
  • Webpack.DefinePlugin:定义全局常量,便于在代码中使用
  • TerserWebpackPlugin:用于压缩JavaScript代码,优化性能
  • OptimizeCSSAssetsPlugin:压缩和优化CSS文件
  • CopyWebpackPlugin:将静态资源复制到输出目录

webpack处理跨域

通过代理的方式,在 webpack.config.js 中使用 devServer 的 proxy 配置

devServer: {proxy: {'/api': {target: 'http://backend-server.com',changeOrigin: true,},},
}

http://www.ppmy.cn/news/1527327.html

相关文章

Nginx节点健康检查与自动上下线管理脚本,推送告警到企业微信

文章目录 案例:Linux 定时任务调取脚本执行场景说明告警脚本(text)check_nginx_tcp_up.shcheck_nginx_tcp_up.logcheck_nginx_tcp_up_run.shcheck_nginx_tcp_up_run.log告警效果案例:Linux 定时任务调取脚本执行 由于需求是每 2 秒执行一次,但 Linux 定时任务最小单位是分…

在线包装盒型生成工具,各种异型包装盒型,PDF导出方便

1、templatemaker.nl Passepartout ✂ Templatemaker ︎https://www.templatemaker.nl/en/passepartout/这是一个荷兰设计师建的一个在线盒型自动生成工具,包含各类新奇盒型,大家可以一起去观摩一下。 网站首页顶部各种盒型展示,大家根据需…

11_Python函数基本概念和示例

函数 函数是组织代码、提高代码复用性的基本工具。一个函数是组织好的、可重复使用的、用来实现单一或相关联功能的代码段。函数类型:内置函数、自定义函数 定义函数 在 Python 中,使用 def 关键字来定义一个函数。 函数可以有参数,也可以…

Git rebase 的使用(结合图与案例)

目录 Git rebase 的使用Git rebase 概念Git rebase 原理rebase和merge的选择 Git rebase 的使用 在 Git 中整合来自不同分支的修改主要有两种方法:merge 以及 rebase Git rebase 概念 **rebase概念:**用来重新应用提交(commits&#xff09…

通过mxGraph在ARMxy边缘计算网关上实现工业物联网

在当今的工业4.0时代,工业物联网(IIoT)已经成为制造业转型升级的关键技术之一。ARMxy边缘计算网关作为工业自动化和物联网的重要组成部分,能够为工厂车间提供实时的数据处理能力和智能化服务。而mxGraph作为一种流行的JavaScript库…

git报错,error: bad signature 0x00000000fatal: index file corrupt

报错 git -c diff.mnemonicprefixfalse -c core.quotepathfalse --no-optional-locks checkout daily --progress error: bad signature 0x00000000 fatal: index file corrupt 原因 git 仓库中索引文损坏 处理 1.该备份的先备份 2.删除索引并重置 rm -f .git/index git r…

在云服务器上安装配置 MySQL 并开启远程访问(详细教程)

前言 MySQL 是最流行的开源关系数据库之一,常用于开发与生产环境中。本文将详细介绍如何在云服务器(如阿里云)上安装 MySQL,并配置允许从远程主机(如本地电脑)进行访问。 环境准备 操作系统:…

安卓网址自动添加%,显示网页异常

最近实现一个功能的时候,需要将接口传递的网址进行包裹处理,然后分享到外部,在安卓分享的时候,会默认将拼接的网址进行编码,将://等进行转码,在点击这个网址的时候就无法进入 例如 // 原始网址let origina…