当前位置: 首页 > news >正文

webpack具体实现--未完

1、前端模块打包工具webpack

webpack 是 Webpack 的核心模块,webpack-cli 是 Webpack 的 CLI 程序,用来在命令行中调用 Webpack。webpack-cli 所提供的 CLI 程序就会出现在 node_modules/.bin 目录当中,我们可以通过 npx 快速找到 CLI 并运行它。npx webpack 会自动从 src/index.js 文件开始打包,然后根据代码中的模块导入操作,自动将所有用到的模块代码打包到一起。之后项目的根目录下多出了一个 dist 目录,我们的打包结果就存放在这个目录下的 main.js 文件中。

2、配置 Webpack 的打包过程

在项目的根目录src下添加一个 webpack.config.js,webpack.config.js 是一个运行在 Node.js 环境中的 JS 文件,也就是说我们需要按照 CommonJS 的方式编写代码,这个文件可以导出一个对象,我们可以通过所导出对象的属性完成相应的配置选项。
 

// ./webpack.config.js
import { Configuration } from 'webpack'  //代码提示
/*** @type {Configuration}*/
const config = {entry: './src/index.js',
//resolve 配置是帮助 Webpack 查找依赖模块的,通过 resolve 的配置,
//可以帮助 Webpack 快速查找依赖,也可以替换对应的依赖output: {filename: 'bundle.js'path: path.join(__dirname, 'output')},
//resolve.extensions是帮助 Webpack 解析扩展名的配置resolve: {extensions: ['.js', '.json', '.css'],alias: {src: path.resolve(__dirname, 'src'),'@lib': path.resolve(__dirname, 'src/lib')}},
//mode: 'development',
}
module.exports = config

3、webpack 构建流程

4、loader原理

Loader本质就是一个函数,在该函数中对接收到的内容进行转换,返回转换后的结果。因为 Webpack 只认识 JavaScript,所以 Loader 就成了翻译官,对其他类型的资源进行转译的预处理工作。

sass-loader与less-loader将代码转换成css。postcss-loader将CSS文件自动添加浏览器前缀。css-loader :允许将css文件通过require的方式引入,并返回css代码,然后将 css 资源转为 CommonJS 的 JS 模块。style-loader将 CommonJS 模块生成一个 style 标签插入到最终的文档中。

use: ['style-loader', 'css-loader', 'postcss-loader']

 file-loader 支持在 JS 模块中引入诸如 png、jpg、svg 等文本或二进制文件,并将文件写出到输出目录

url-loader  可以识别图片的大小,当文件小于给定的阈值时把图片转换成内联的base64 URL,这会减少小文件的 HTTP 请求数。如果文件大于该阈值,会自动的交给 file-loader 处理。

vue-loader是用于处理单文件组件。 script 块中的内容被作为 js 处理,对所有*.js 配置了 babel-loader。需要用 Vue 模板编译器编译 template,从而得到 render 函数。需要对<style scoped>中的 CSS 做后处理(post-process),该操作在 css-loader 之后但在 style-loader 之前

5、Plugin

Plugin就是插件,基于事件流框架Tapable,插件可以扩展 Webpack 的功能,基于发布订阅模式(类似于eventbus),在 Webpack 运行的生命周期中会广播出许多事件,Plugin 可以监听这些事件,在合适的时机通过 Webpack 提供的 API 改变输出结果。

Plugin从本质上来说,就是一个具有apply方法Javascript对象。apply 方法会被 webpack compiler 调用,并且在整个编译生命周期都可以访问 compiler 对象。

const pluginName = 'ConsoleLogOnBuildWebpackPlugin';class ConsoleLogOnBuildWebpackPlugin {apply(compiler) {compiler.hooks.run.tap(pluginName, (compilation) => {console.log('webpack 构建过程开始!');});}
}module.exports = ConsoleLogOnBuildWebpackPlugin;

entry-option :初始化 option

compile: 真正开始的编译,在创建 compilation 对象之前

compilation :生成好了 compilation 对象

make:从 entry 开始递归分析依赖,准备对每个模块进行 build

after-compile: 编译 build 过程结束

emit :在将内存中 assets 内容写到磁盘文件夹之前

after-emit :在将内存中 assets 内容写到磁盘文件夹之后

done: 完成所有的编译过程 - failed: 编译失败的时候

参考:谈谈你对Webpack的理解 - 掘金 (juejin.cn)

6、bable解释流程

参考:babel 处理流程管窥 - 知乎 (zhihu.com)

  • 解析过程基于 @babel/parser 做词法分析、语法分析。词法分析将源程序解析成令牌流;语法分析将令牌流转换成 AST。
  • 转换过程基于 @babel/traverse 遍历 AST,对节点进行添加、更新及移除等操作。此时插件将介入工作。
  • 生成过程基于 @babel/generator 深度遍历 AST,将其转换成字符串形式的代码,并生成 source maps 源码映射。

相关文章:

webpack具体实现--未完

1、前端模块打包工具webpack webpack 是 Webpack 的核心模块&#xff0c;webpack-cli 是 Webpack 的 CLI 程序&#xff0c;用来在命令行中调用 Webpack。webpack-cli 所提供的 CLI 程序就会出现在 node_modules/.bin 目录当中&#xff0c;我们可以通过 npx 快速找到 CLI 并运行…...

【Git】修改提交信息(单次、批量)

文章目录 修改最近一次 commit 的提交信息修改某次 commit 的提交信息方法总结 修改最近一次 commit 的提交信息 git commit --amend -m "new message"修改某次 commit 的提交信息 git log --oneline 运行结果如下2f80f1b commit 4 9ee990a 第三次提交 40f2f03 comm…...

Grafana Panel组件跳转、交互实现

程序员的公众号&#xff1a;源1024&#xff0c;获取更多资料&#xff0c;无加密无套路&#xff01; 最近整理了一份大厂面试资料《史上最全大厂面试题》&#xff0c;Springboot、微服务、算法、数据结构、Zookeeper、Mybatis、Dubbo、linux、Kafka、Elasticsearch、数据库等等 …...

人工智能|机器学习——感知器算法原理与python实现

感知器算法是一种可以直接得到线性判别函数的线性分类方法&#xff0c;它是基于样本线性可分的要求下使用的。 一、线性可分与线性不可分 为了方便讨论&#xff0c;我们蒋样本增加了以为常数&#xff0c;得到增广样向量 y&#xff08;1;;;...;&#xff09;,则n个样本的集合为&a…...

【论文阅读笔记】Prompt-to-Prompt Image Editing with Cross-Attention Control

【论文阅读笔记】Prompt-to-Prompt Image Editing with Cross-Attention Control 个人理解思考基本信息摘要背景挑战方法结果 引言方法论结果讨论引用 个人理解 通过将caption的注意力图注入到目标caption注意力中影响去噪过程以一种直观和便于理解的形式通过修改交叉注意力的…...

Echarts legend图例配置项 设置位置 显示隐藏

Echarts 官网完整配置项 https://echarts.apache.org/zh/option.html#legend 配置项 legend: { }设置图例为圆形 icon: circle,//设置图例为圆形设置图例位置 top: 20%//距离顶部百分之20//y:bottom 在底部显示设置图例 宽度 高度 itemWidth: 10,//设置图例宽度 itemHeight: …...

C#每天复习一个重要小知识day3:随机数的生成

目录 格式&#xff1a; 生成随机数&#xff1a; 生成一个0-100的随机数&#xff1a; 以下是更详细的代码示例&#xff1a; 在C#中&#xff0c;可以使用Random类来生成随机数。这个类提供了多种方法来生成不同类型的随机数。 格式&#xff1a; Random 随机变量名(r) new …...

Java后端使用XWPFDocument生成word文档,踩坑

以下都是借鉴网上内容: 环境 纯后端, java, spring项目 maven管理. maven内容: <dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>3.16</version></dependency><dependency>…...

asp.net core HttpContextAccessor类

在 ASP.NET Core 中 &#xff0c;HttpContextAccessor 是一个用于访问当前 HTTP 请求的工具类。它通常用于在应用程序中获取当前 HTTP 请求的上下文信息&#xff0c;例如请求的路由、头部信息、用户身份验证状态等。 HttpContextAccessor 类通常在需要访问当前 HTTP 请求上下文…...

微服务--04--SpringCloudGateway 网关

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.网关路由1.1 认识网关在SpringCloud当中&#xff0c;提供了两种网关实现方案&#xff1a; 1.2.快速入门1.3.路由过滤 2.网关登录校验2.1.鉴权思路分析2.2.网关过滤…...

Java程序连接 nacos集群

我们在bootstrap.yml文件里可以直接连一个nacos集群的. 架构如下 没错,我们程序直连的是通过Nginx的,利用nginx的反向代理来做到连接nacos集群. 我们先把nginx的配置贴上来 upstream cluster{server 127.0.0.1:8848;server 127.0.0.1:8849;server 127.0.0.1:8850; }server{l…...

【深度学习】参数优化和训练技巧

寻找合适的学习率(learning rate) 学习率是一个非常非常重要的超参数&#xff0c;这个参数呢&#xff0c;面对不同规模、不同batch-size、不同优化方式、不同数据集&#xff0c;其最合适的值都是不确定的&#xff0c;我们无法光凭经验来准确地确定lr的值&#xff0c;我们唯一可…...

CeresPCL 曲线拟合之三次多项式

文章目录 一、简介2.1 实现步骤二、实现代码三、实现效果参考资料一、简介 2.1 实现步骤 (1)构建代价函数。假设我们得到了一组数据,也知晓该数据是用曲线方程: y = a x 3 + b x 2 + c x +...

小白备战蓝桥杯:Java基础语法

一、注释 IDEA注释快捷键&#xff1a;Ctrl / 单行注释&#xff1a; //注释信息 多行注释&#xff1a; /* 注释信息 */ 二、字面量 常用数据&#xff1a;整数、小数、字符串&#xff08;双引号&#xff09;、字符&#xff08;单引号&#xff09;、布尔值&#xff08;tr…...

C#面向对象

过程类似函数只能执行没有返回值 函数不仅能执行&#xff0c;还可以返回结果 1、面向过程 a 把完成某一需求的所有步骤 从头到尾 逐步实现 b 根据开发需求&#xff0c;将某些 功能独立 的代码 封装 成一个又一个 函数 c 最后完成的代码就是顺序的调用不同的函数 特点 1、…...

智能优化算法应用:基于蝙蝠算法无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于蝙蝠算法无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于蝙蝠算法无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.蝙蝠算法4.实验参数设定5.算法结果6.参考文献7.MATLAB…...

【栈和队列(1)(逆波兰表达式)】

文章目录 前言什么是栈(Stack)栈方法栈的模拟实现链表也可以实现栈逆波兰表达式逆波兰表达式在栈中怎么使用 前言 什么是栈(Stack) 栈&#xff1a;一种特殊的线性表&#xff0c;其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0…...

Blazor Table 实现获取当前选中行的功能

这里需要使用到OnClickRowCallBack事件 后台使用案例...

Flask Echarts 实现历史图形查询

Flask前后端数据动态交互涉及用户界面与服务器之间的灵活数据传递。用户界面使用ECharts图形库实时渲染数据。它提供了丰富多彩、交互性强的图表和地图&#xff0c;能够在网页上直观、生动地展示数据。ECharts支持各种常见的图表类型&#xff0c;包括折线图、柱状图、饼图、散点…...

【漫谈】信创

近些年来&#xff0c;自主创新绝对是高频词汇。 以往是供应链、芯片领域&#xff0c;现在终于到了信息领域。 近期&#xff0c;从上至下、从中央到地方、从政府到国企&#xff0c;各层面、各行业、各领域都在提及“信创”。 信创是个大工程&#xff0c;从计算机通用处理器、…...

Agenda嵌入式调度库:抗溢出、协作式Arduino任务管理方案

1. Agenda调度库概述Agenda是一个专为Arduino平台设计的轻量级、非中断驱动型任务调度库&#xff0c;其核心目标是提供一种抗溢出&#xff08;overflow-proof&#xff09;、高可靠性且资源可配置的时间管理方案。该库由Giovanni Blu Mitolo于2013年开发&#xff0c;最初服务于高…...

VMware Horizon Client安全连接失败?Fiddler HTTPS拦截惹的祸(附详细解决方案)

VMware Horizon Client安全连接失败的深度排查与解决方案 当你正专注于远程办公或虚拟桌面环境的管理时&#xff0c;突然遭遇VMware Horizon Client无法建立安全连接的情况&#xff0c;这种中断不仅影响工作效率&#xff0c;还可能引发数据同步的连锁问题。特别是在使用Fiddler…...

丹青识画系统在卷积神经网络上的优化:提升图像特征提取效率

丹青识画系统在卷积神经网络上的优化&#xff1a;提升图像特征提取效率 最近在折腾一个图像识别项目&#xff0c;用到了丹青识画系统。说实话&#xff0c;刚开始部署完&#xff0c;跑起来的效果虽然不错&#xff0c;但那个推理速度实在是让人有点着急&#xff0c;处理一张高清…...

收藏!小白程序员快速入门大模型:23个核心概念轻松掌握

本文介绍了23个AI领域最常见的核心概念和术语&#xff0c;旨在帮助普通人与AI工具更好地打交道。文章从人工智能的基本定义出发&#xff0c;详细解释了机器学习、深度学习、神经网络、生成式AI、大语言模型等核心概念&#xff0c;并拓展了模型、训练、推理、幻觉等关键技术方法…...

别再傻傻分不清!一张图看懂EtherCAT从站Startup list和CoE-online的核心差异与应用选型

EtherCAT从站配置双刃剑&#xff1a;Startup list与CoE-online的实战抉择指南 第一次接触EtherCAT从站配置时&#xff0c;面对Startup list和CoE-online这两个选项&#xff0c;不少工程师都会陷入选择困难。这两种配置方式看似都能实现参数设定&#xff0c;但底层逻辑和适用场景…...

茶叶病害目标检测数据集 茶叶病害识别管理系统 数据集+界面+模型 识别功能包括登录、导入模型、图片、视频、实时检测

01 — 茶叶病害目标检测&#xff08;数据集/界面 基于YOLO全系列&#xff0c;界面非常美观&#xff0c;非常详细&#xff09;模块/类别 详细说明 一、技术栈编程语言&#xff1a;PythonGUI框架&#xff1a;PyQt5&#xff08;界面美观、操作友好&#xff09;目标检测模型框架&am…...

FireRedASR-AED-L实现Python语音识别:从音频到文本的完整教程

FireRedASR-AED-L实现Python语音识别&#xff1a;从音频到文本的完整教程 1. 引言 语音识别技术正在改变我们与设备交互的方式&#xff0c;从智能助手到实时字幕&#xff0c;这项技术已经深入到日常生活的方方面面。今天我要介绍的FireRedASR-AED-L&#xff0c;是一个专门为中…...

从零搭建工业级Java Agent:Claude Code架构拆解完整教程

引言&#xff1a;随着AI Agent技术的爆发&#xff0c;越来越多开发者想从0到1掌握Agent的设计与落地&#xff0c;但市面上大多教程停留在“概念讲解”&#xff0c;缺乏与真实项目结合的实操指导。本文基于Claude Code&#xff08;Java版&#xff09;项目&#xff0c;拆解12节渐…...

实现点击目标图片时随机重定位的完整教程

本文详解如何让 html 元素&#xff08;如靶心图片&#xff09;在每次点击时都重新生成随机坐标并平滑移动到新位置&#xff0c;解决“仅首次生效”问题&#xff0c;关键在于将随机计算逻辑置于事件函数内部&#xff0c;并确保 css 定位正确。 本文详解如何让 html 元素&am…...

HTML5中Mediastream实现摄像头画面实时捕获

HTML5通过MediaStream API可直接调用摄像头&#xff1a;先用navigator.mediaDevices.getUserMedia({video:true})获取流并赋给video.srcObject&#xff0c;再用canvas逐帧绘制处理&#xff1b;需处理权限异常、复用流、设置约束参数&#xff0c;并注意HTTPS和移动端autoplay/mu…...