webpack loader
1、分类

2、执行顺序

配置类型

执行顺序是 loader1>loader2>loader3
3、使用方式

自己的第一个loader
同步loader
/*** loader 就是一个函数* 当webpack 解释资源时, 会调用相应的loader去处理* loader 接收到文件内容作为参数,返回文件内容* @param {*} content 文件内容* @param {*} map SourceMap* @param {*} meta 别的loader 传递过来的数据*/
module.exports = function(content, map, meta){console.log('main.js 传过来的数据', content);return content
}/*** 当需要传递参数给其他 loader 的loader 写法*/// module.exports = function (content,map, meta) {
// // 第一个参数: err 代表是否有错误
// // 第二个参数:content 处理后的内容
// // 第三个参数: source-map 继续传递source-map
// // 第四个参数:meta 给下一个loader传递参数
// this.callback(null,content,map,meta);
// }

会在vscode 终端看到

异步loader (同步loader不能调用异步方法)
module.exports = function(content, map, meta){const callback = this.async()setTimeout(()=>{console.log('异步操作');callback(null, content, map, meta)}, 1000)
}
raw loader,处理图片、svg等时会用到
// 同步异步操作均可以
module.exports = function(content, map, meta){console.log('raw-loader Buffer数据流', content);return content
}module.exports.raw = true

目前 只有 main.js 文件
console.log('hello word');
patch loader
执行顺序

// pitch-loader1.js
module.exports = function(content, map, meta){console.log('pitch-loader1');return content
}module.exports.pitch = function(content, map, meta){console.log('pitch1');
}// pitch-loader2.js
module.exports = function(content, map, meta){console.log('pitch-loader2');return content
}module.exports.pitch = function(content, map, meta){console.log('pitch2');
}// pitch-loader.js
module.exports = function(content, map, meta){console.log('pitch-loader3');return content
}module.exports.pitch = function(content, map, meta){console.log('pitch3');
}
webpack.config.js 配置

打印结果

如果patch中有return 则不糊执行后续的操作,而是直接返回到上一个loader执行,如果没有就不用执行,下面是在loader中有返回值的意思,直接返回到loader执行操作

4、loader Api
this.getOptions 获取options

schema.json

打包后文件中就会多出坐着相关信息

5、简单重写一下常用的部分loader
babel-loader
const babel = require('@babel/core')
const schema = require("./schema.json")module.exports = function(content, map, meta){// 获取webpack 使用这个loader 时的options配置项const callback = this.async()const options = this.getOptions(schema)babel.transform(content, options, function(err, result){if(err) callback(err)else callback(null, result.code)})
}
schema.json
{"type":"object","properties":{"presets":{"type": "array"}},"additionalProperties": false
}
webpack 中的使用

file-loader (使用到this.emitFile函数)

webpack 配置
stylle-loader
主要作用,通过js代码创建一个style标签 ,然后将样式代码加进去
这里 module.exports = function(){} 空函数即可
如果,想要更深一步学习loader, 可以去看看常用的loader的源码
相关文章:
webpack loader
1、分类 2、执行顺序 配置类型 执行顺序是 loader1>loader2>loader3 3、使用方式 自己的第一个loader 同步loader /*** loader 就是一个函数* 当webpack 解释资源时, 会调用相应的loader去处理* loader 接收到文件内容作为参数,返回文件内容* p…...
Java—学生信息管理系统(简单、详细)
文章目录 一、主界面展示二、学生类三、系统功能方法3.1 main()方法3.2 添加学生信息3.3 删除学生信息3.4 修改学生信息3.5 查看所有学生信息 四、完整代码4.1 Student .Java4.2 StudentManger.Java 前言:本案例在实现时使用了Java语言中的ArrayList集合来储存数据。…...
Spring第一课,了解IDEA里面的文件,回顾Cookie和Session,获取Session,Cookie,Header的方式
目录 IDEA第一课(熟悉里面内容) 建立连接 -RequestMapping 路由映射 请求 1.传递单个参数编辑 2.多个参数编辑 3.传递数组 4.传递一个集合,但是这里我们传递的时候发生了500的错误 简单介绍JSON 回顾Cookie和S…...
AcWing113.特殊排序
题目 有 N N N 个元素,编号 1 , 2.. N 1,2..N 1,2..N,每一对元素之间的大小关系是确定的,关系具有反对称性,但不具有传递性。 注意:不存在两个元素大小相等的情况。 也就是说,元素的大小关系是 N N N…...
数据仓库岗面试
1.自我介绍 2.求用户连续登录3天,要讲出多种解法 解法1(使用SQL): SELECTuserid FROMloginrecord WHEREDATEDIFF(day, time, LAG(time) OVER (PARTITION BY userid ORDER BY time)) 1AND DATEDIFF(day, LAG(time) OVER (PARTI…...
企业建数仓的第一步是选择一个好用的ETL工具
当企业决定建立数据仓库(Data Warehouse),第一步就是选择一款优秀的ETL(Extract, Transform, Load)工具。数据仓库是企业数据管理的核心,它存储、整合并管理各种数据,为商业决策和数据分析提供支…...
行情分析 - - 加密货币市场大盘走势(11.23)
大饼昨日又开始了回调,因为FTF消息,而实际还是要下跌的,耐心等待即可。 空单策略:入场37300 止盈34000-33000 止损39000 以太昨日上涨也很激励,目前上涨打了止损,现在入场是好的机会,等待即可。…...
穿山甲SDK 集成·android接入广告·app流量变现
接入穿山甲SDK的app 数独训练APP 广告接入示例: Android 个人开发者如何接入广告SDK,实现app流量变现 接入穿山甲SDK app示例: android 数独小游戏 经典数独休闲益智 随着移动互联网的快速发展,广告成为了许多应用开发者获取收益的主要方…...
深度学习模型训练计算量的估算
深度学习模型训练计算量的估算 方法1:基于网络架构和批处理数量计算算术运算次数前向传递计算和常见层的参数数量全连接层(Fully connected layer)参数浮点数计算量 CNN参数浮点数计算量 转置CNN参数浮点数计算量 RNN参数浮点数计算量 GRU参数…...
【实验笔记】C语言实验——降价提醒机器人
降价提醒机器人 题目: 小 T 想买一个玩具很久了,但价格有些高,他打算等便宜些再买。但天天盯着购物网站很麻烦,请你帮小 T 写一个降价提醒机器人,当玩具的当前价格比他设定的价格便宜时发出提醒。 输入格式…...
YOLOv5分割训练,从数据集标注到训练一条龙解决
最近进行了分割标注,感觉非常好玩,也遇到了很多坑,来跟大家分享一下,老样子有问题评论区留言,我会的就会回答你。 第一步:准备数据集 1、安装标注软件labelme如果要在计算机视觉领域深入的同学࿰…...
再添千万级罚单,某银行年内罚款过亿!金融行业合规问题亟待解决
11月17日晚间,国家金融监管总局上海监管局披露行政处罚信息显示,某银行因32项违法违规事实收到两张690万元的大额罚单,合计罚款金额达1380万元。但这并不是银行该今年收到的第一张大额罚单。今年4月28日,该行因在结售汇、外币理财…...
配置Nginx服务器用于Web应用代理和SSL{仅配置文件}
在本篇博文中,我们将深入讨论如何配置Nginx服务器,使其成为一个强大的Web应用代理,并通过SSL协议加强通信的安全性。 1. 服务器监听与SSL设置 首先,我们要配置Nginx服务器以监听HTTPS流量并设置SSL证书,确保通信的安…...
【广州华锐互动】VR溺水预防教育:在虚拟世界中学会自救!
在现代社会中,水上安全和救援行动的重要性不言而喻。尤其在自然灾害、游泳事故或航海事故中,有效的救援行动可以挽救许多生命。然而,传统的救援训练往往存在成本高、风险大、效率低等问题。在这样的背景下,虚拟现实(VR…...
Si(111)衬底上脉冲激光沉积AlN外延薄膜的界面反应控制及其机理
引言 通过有效控制AlN薄膜与Si衬底之间的界面反应,利用脉冲激光沉积(PLD)在Si衬底上生长高质量的AlN外延薄膜。英思特对PLD生长的AlN/Si异质界面的表面形貌、晶体质量和界面性能进行了系统研究。 我们研究发现,高温生长过程中形…...
基于Cortex®-M4F的TM4C123GH6NMRT7R 32位MCU,LM74900QRGERQ1、LM74930QRGERQ1汽车类理想二极管
一、TM4C123GH6NMRT7R IC MCU 32BIT 256KB FLASH 157BGA Tiva™C系列微控制器为设计人员提供了基于ARMCortex™-M的高性能架构,该架构具有广泛的集成功能以及强大的软件和开发工具生态系统。以性能和灵活性为目标,Tiva™C系列架构提供了一个具有FPU的80…...
苹果企业签名失败常见的问题
苹果企业签名失败的常见问题主要有以下几种: 证书过期或无效:苹果开发者需要定期更新他们的签名证书,以确保其有效性。一旦证书过期,相关应用将无法正常工作。证书不匹配:如果使用的证书与应用程序的Bundle ID不匹配&…...
Jtti:Android alertdialog嵌套出错怎么解决
在Android开发中,AlertDialog嵌套可能导致一些问题,例如显示异常或无法关闭对话框等。这通常是由于上一个AlertDialog未被正确关闭,导致下一个AlertDialog无法正常工作。解决这个问题的方法包括: 1. 确保关闭上一个AlertDialog&a…...
解锁word密码,忘记密码怎么办?
想要解密、找回或去除Word文档密码,可以按以下步骤操作:第一步,在百度上搜索【密码帝官网】,接着在用户中心上传需要解密的文件即可。这种方法安全、简单易操作,而且不用下载软件,手机和电脑都可以用。无论…...
同为科技(TOWE)桌面PDU插排:一款可以DIY定制的“超级插座”
当今社会,各种电子产品和家用电器已成为人们日常生活中不可或缺的一部分,在带给人们便利的同时,也使得电力使用变得更加频繁和重要。然而,当前市面上很多普通插座由于功能单一、材质粗劣、插口数量受限、充电速度过慢、插头间互相…...
Windows STL文件缩略图终极指南:告别3D模型管理混乱的革命性解决方案
Windows STL文件缩略图终极指南:告别3D模型管理混乱的革命性解决方案 【免费下载链接】STL-thumbnail Shellextension for Windows File Explorer to show STL thumbnails 项目地址: https://gitcode.com/gh_mirrors/st/STL-thumbnail 还在为Windows文件资源…...
自动驾驶的“夜视眼”如何炼成?深入拆解跨模态图像融合中的对齐难题
自动驾驶的“夜视眼”如何炼成?深入拆解跨模态图像融合中的对齐难题 凌晨3点的城市高架桥上,一辆自动驾驶测试车正以60公里时速巡航。突然,前方200米处出现一个横穿马路的行人——红外传感器捕捉到了人体热辐射,但可见光摄像头因路…...
OpenClaw-Suite:多模态AI自动化工具箱架构解析与实战部署
1. 项目概述:一个面向多模态AI自动化的工具箱 如果你正在寻找一个能帮你把AI能力“塞”进QQ、微信、Telegram等日常聊天工具,并且还能处理图片、语音、文件,甚至能自己跑定时任务的“瑞士军刀”级项目,那么 openclaw-suite 值得…...
解锁Win10新姿势:用WSL2+AirSim+PX4+MAVROS搭建你的无人机算法“炼丹炉”
解锁Win10新姿势:用WSL2AirSimPX4MAVROS搭建你的无人机算法“炼丹炉” 当无人机算法开发遇上Windows系统,传统认知总认为这是条荆棘之路——直到WSL2的出现彻底改变了游戏规则。想象一下,在熟悉的Windows环境中,你既能享受Linux的…...
Arm嵌入式C/C++库定制与优化实践
1. Arm嵌入式C/C库定制基础在嵌入式开发领域,标准C/C库的定制能力直接决定了系统资源的利用效率。Arm Compiler for Embedded提供的库函数支持深度定制,特别适合在资源受限的裸机或RTOS环境中使用。1.1 裸机环境下的库函数使用当开发不带main()函数的裸机…...
Flask Debug PIN码破解实战:手把手教你从信息泄露到获取交互式控制台权限
Flask Debug PIN码安全攻防实战:从信息泄露到交互式控制台入侵 当你发现一个Flask应用意外开启了调试模式时,眼前突然出现的Werkzeug调试器就像一扇半掩的门——它既可能是开发者的救命稻草,也可能成为攻击者的黄金机会。本文将带你深入探索F…...
别再让CPU拖后腿!用PyTorch CUDA Graph给vLLM推理加速5倍(附完整代码)
突破vLLM推理性能瓶颈:CUDA Graph实战优化指南 在部署大语言模型推理服务时,许多团队发现即使采用了vLLM这样的高效推理引擎,GPU利用率仍然难以突破60%的瓶颈。通过Nsight Systems工具分析,我们会发现大量时间消耗在CPU调度环节—…...
LFM2-2.6B-GGUF快速上手:WebUI清空对话+历史记录管理技巧
LFM2-2.6B-GGUF快速上手:WebUI清空对话历史记录管理技巧 1. 认识LFM2-2.6B-GGUF模型 LFM2-2.6B-GGUF是由Liquid AI公司开发的一款轻量级大语言模型,经过GGUF量化处理后,在保持良好性能的同时大幅降低了资源需求。这个模型特别适合在资源有限…...
MedGemma 1.5保姆级教程:无需联网,6006端口快速启动本地医疗AI
MedGemma 1.5保姆级教程:无需联网,6006端口快速启动本地医疗AI 你是不是也有过这样的经历?身体有点不舒服,想上网查查资料,结果要么被一堆广告淹没,要么看到各种吓人的说法,越看心里越没底。想…...
Gems 捷迈 FT-110 工业级涡轮式低流量传感器的国产替代方案
Gems 捷迈 FT-110 系列流量传感器,是一款专为低流量液体监测打造的工业级涡轮式检测设备,凭借精准的测量性能、紧凑的结构设计与稳定的运行表现,广泛适配各类OEM应用场景,可高效完成液体瞬时流量与累积流量的精准采集,…...
