news 2026/4/23 12:44:34

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/22 23:44:04

手把手教你用Gemini 3.0 Flash自动生成游戏APP,小白也能30分钟搞定!

哈喽各位小伙伴&#xff5e; 是不是总觉得做游戏APP是程序员的专属技能&#xff1f;代码、调试、上架一套下来头都大了&#x1f635;&#xff1f;但今天我要告诉大家&#xff1a;2026年的AI已经卷到能直接帮你生成完整游戏APP了&#xff01;用Google最新的Gemini 3.0 Flash模型…

作者头像 李华
网站建设 2026/4/23 11:20:36

你不是没能力,是没选对赛道:测试人转型AI的3个黄金入口

在软件测试领域&#xff0c;自动化工具的普及正重塑职业格局&#xff0c;许多测试从业者面临技能冗余的焦虑。但问题不在于能力不足&#xff0c;而在于未发掘AI浪潮中的新赛道。测试工程师的严谨逻辑、缺陷分析能力与流程优化经验&#xff0c;正是AI时代稀缺的“软黄金”。转型…

作者头像 李华
网站建设 2026/4/13 15:52:40

硬核解读:从RunaCap榜单到技术内幕,RustFS的“全球级”潜力由何而来?

一张来自卢森堡的榜单&#xff0c;让一个中国开源的存储项目站在了国际资本的聚光灯下&#xff0c;这背后折射出的不只是单个项目的崛起&#xff0c;更是一场关于技术信仰与市场选择的深刻变局。 2025年第四季度&#xff0c;一则消息在技术圈内激起涟漪&#xff1a;国产开源分布…

作者头像 李华
网站建设 2026/4/21 6:50:49

DeepSeek辅助总结的chdb 4.0发版说明

chDB chDB 是一个由 ClickHouse 驱动、进程内运行的 SQL OLAP 引擎 [^1] 更多详情&#xff1a;chDB 的诞生 特性 &#x1f43c; 兼容 Pandas 的 DataStore API - 使用熟悉的 pandas 语法&#xff0c;获得 ClickHouse 性能由 ClickHouse 驱动的进程内 SQL OLAP 引擎无需安装 Cl…

作者头像 李华
网站建设 2026/4/22 17:29:10

NSCAT 3 级每日网格化海洋表面风矢量浏览图像(JPL)

NSCAT Level 3 Daily Gridded Ocean Surface Wind Vector Browse Images (JPL) 简介 本数据集提供美国宇航局散射计&#xff08;NSCAT&#xff09;3 级每日网格化海洋风矢量的浏览图像&#xff0c;升轨和降轨的风矢量空间分辨率均为 0.5 度&#xff1b;相邻轨道重叠处的风矢量…

作者头像 李华
网站建设 2026/4/18 6:43:47

实时图像处理优化

1、非修改序列算法 这些算法不会改变它们所操作的容器中的元素。 1.1 find 和 find_if find(begin, end, value)&#xff1a;查找第一个等于 value 的元素&#xff0c;返回迭代器&#xff08;未找到返回 end&#xff09;。find_if(begin, end, predicate)&#xff1a;查找第…

作者头像 李华