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

webpack - 常用的 CSS 加载器(webpack与其常见loader加载器使用方式)

css-loader 处理css中路径引用等问题

用于在js中加载css,解释@import和url()

options

  1. alias: 解析别名
  2. importLoaders(@import): 在css-loader前应用的loader的数目,默认为0
  3. Minimize: true or false 是否开启css代码压缩,比如压缩空格不换行
  4. modules: 是否开启css-module
module.exports={...module:{rules:[{test:/\.css$/,use:['style-loader',{loader:'css-loader',options:{//当css文件中又引用了其他的css的时候,需要设置importLoadersimportLoaders:1}}]}]}};

style-loader 动态把样式写入css

加载的css作为style标签内容插入到html中,以<style></style>形式在html页面中插入css代码

options

  1. insertAt: 插入位置
  2. insertInto: 插入到指定的dom
  3. singleton: true or false,多个样式是否只生成一个<style></style>标签

postcss-loader

postcss-loader:为了浏览器的兼容性,有时候我们必须加上-webkitm, -ms, -moz等前缀。目的就是让页面可以在每个浏览器上正常运行。postcss是一个CSS的处理平台可以帮CSS实现更多的功能。

用法:

安装 postcss:npm install postcss-loader autoprefixer

配置文件

webpack.config.js:module:{rules:[{test:/\.css$/loader:'style-loader!css-loader!postcss-loader'}]}postcss.config.js module.exports={plugins:[require('autoprefixer')//在postcss-loader中引入autoprefixer插件]}

或者

constautoprefixer=require('autoprefixer');module:{rules:[{test:/\.css$/,use:['style-loader','css-loader',{loader:'postcss-loader',options:{plugins(){return[autoprefixer];}}}]}]}

less-style

添加对webpack的LESS支持。当遇到less文件时,先交给less-loader处理,然后交给css-loader,最后交由style-loader处理,然后执行webpack打包

module:{rules:[{test:/\.less$/,loader:'style-loader!css-loader!less-loader'}]}

要启用CSS的source map,你需要将sourceMap选项传递给less-loader和css-loader

CSS SourceMap信息文件,里面存储着位置信息。随着代码增多,我们会对代码进行压缩,代码压缩之后进行调bug定位会非常困难,于是引入sourceMap记录压缩前后的位置信息,当产生错误时直接定位到未压缩前的位置,方便调试。简单来说就是记录压缩的翻译文件,通过这个文件可以找到你的对应源码

module.exports={...module:{rules:[{test:/\.less$/,use:['style-loader','css-loader',{loader:'less-loader',options:{sourceMap:true}}]}]}};

less-loader可用的options:
modifyVars 或 globalVars声明全局变量: {Object},在less使用全局变量时,我们可以定义一个全局变量的文件,然后每次使用时都引用这个文件,显而易见,这个方法很麻烦。less还提供了另外的方法来声明全局变量,即在options.globalVars/options.modifyVars里进行配置。

modifyVars修改全局的less变量, globalVars声明全局的less变量

module.exports={...module:{test:/\.less$/,use:['style-loader','css-loader,{loader:'less-loader',options:{midifyVars:{@bgColor:red;//或者bgColor: red,有没有@都可以}/*globalVars: { @bgColor: red; }*/}}]}};
body{background-color:@bgColor;//使用时必须有@}

编译后

body{background-color:red;}
http://www.jsqmd.com/news/313585/

相关文章:

  • 中医执助考试备考难?全网深度测评,帮你锁定最强机构!
  • 嘎嘎降AI vs 比话降AI:知网/维普/万方实测对比,选哪个更划算
  • 2026主管护师相关专业知识怎么备考?应试技巧+高频考点,快速提分通关攻略
  • 论文降AI不想被收录?这款工具承诺不公开不入库
  • 2026执业药师考试备考平台推荐:从口碑排行到性价比,这篇测评全说清
  • DeepSeek写的论文AI率太高?5分钟降到知网合格线以下
  • 2026执业药师考试备考平台推荐:考生真实实测对比,这份推荐清单很靠谱!
  • 2026 执业药师刷题 app 推荐:高口碑刷题工具实力榜出炉!
  • 2026 执业药师刷题 app 推荐:这三款靠谱推荐,备考效率翻倍!
  • HTML--段落换行下划线标签
  • 执业医师考试课程选这个,让你的备考效率翻倍!
  • 程序员的苦,你不懂
  • 手把手教你用Gemini 3.0 Flash自动生成游戏APP,小白也能30分钟搞定!
  • 【Agent从入门到实践】41 部署方式选型:本地脚本、Docker容器、云服务部署
  • AUTOSAR如何评估BSW模块裁剪的最小集合以满足轻量级ECU?
  • 配网两阶段鲁棒优化调度模型 关键词:两阶段鲁棒优化,CCG算法,储能 仿真算例采用33节点
  • HTML简介
  • MySQL大表优化实战:5大核心问题+6套落地解法(附SQL示例)
  • 一句话把 B 站视频合集变成教程网站,这是什么神仙操作 ?MiniMax Agent 的专家功能,值得一试!
  • 深入解析:简明教程:记录 Ubuntu系统命令行安装TexLive,配置vscode
  • 2026年养老机器人关键技术深度解析与主流品牌评测
  • 【Agent从入门到实践】42实战:用Docker打包Agent,实现一键部署
  • 为什么你的测试团队总在“重复造轮子”?
  • TestOps的“测试执行统计”:谁跑得最多?谁最稳定?
  • 电子保单的数字化助力
  • PCB表面缺陷检测:如何从数据到模型实战
  • 构建你的Python作品集:5个绝佳项目创意
  • 从0开始进军大厂-Day02
  • 从知识沉淀到智能调度:AI调度官的 Coze 数据库实现逻辑
  • 断网、断电,不断数据——LoongCollector 极限边缘场景可靠采集方案