【Webpack】样式处理 - 样式预处理

样式预处理是在开发中会使用一些样式预编译语言,如scss,less等,在项目打包过程中再将这些语言转换为css,借助这些语言强大和便捷的特性,可以降低项目的开发和维护成本。
下面是目前最主流的两种预编译语言是如何配置的

sass和scss

sass本身是对css的语法增强,现在使用更多的是scss
在安装和配置都是sass-loader,而实际的文件后缀是.scss
sass-loader就是将scss语法编译为css,因此在使用时通常还要搭配css-loader和style-loader。loader本身只是编译核心库和webpack的连接器,因此还要安装node-sass,node-sass是真正用来编译scssde
用npm install 来安装包

接着来添加处理scss文件的webpack配置

module:{rules:[{test:/\.scss$/,use:{'style-loader','css-loader','sass-loader'}}]
}

另外,如果想要在浏览器的调试工具里查看源码,需要分别为sass-loader和css-loader单独添加source map的配置想

module:{rules:[{test:/\.scss$/,use:['style-loader',{loader:'css-loader',options:{sourceMao:true},},{loader:'sass-loader',options:{sourceMao:true},},]}]
}

less

less也是对css的一种扩展,与scss类似,也需要安装loader和其本身编译模块,在配置上也和scss十分类似

module:{rules:[{test:/\.less/,use:['style-loader',{loader:'css-loader',options:{sourceMao:true},},{loader:'less-loader',options:{sourceMao:true},},]}]
}

less支持多种编译过程中的配置,可以直接通过loader的options将这些配置传入(注意使用驼峰命名)

css modules

css modules是最近比较流行的一种开发模式,其理念是把css模块化,让css也拥有模块的特点,具体如下:

  1. 每个css文件中的样式都拥有单独的作用域,不会和外界发生命名冲突
  2. 对css进行依赖管理,可以通过相对路径引入css文件
  3. 可以通过composes轻松复用其他css模块

使用css modules不需要额外安装模块,只要开启css-loader中的modules配置项即可

module:{rules:[{test:/\.css/,use:['style-loader',{loader:'css-loader',options:{sourceMao:true,locaIdentName:'[name]__[local]__[hash:base64:5]',},},]}]
}

这里localIdentName配置项是用于指明css代码中的类名会如何来编译,例如,源码是下面的形式:

.title{color:#f938ab
}

经过编译后可能将成为.style__title__1CFy6
因此上面的参数可以解释为
[name]指的是模块名,这里被替换为style
[local]指代的是原本的选择器标识符,这里被替换为title
[hash:base64:5]指代的是一个5位的hash值,这个值是根据模块名和标识符计算的,因此不同模块中相同的标识符也不会造成样式冲突

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/16960.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flink 数据源

原理 在 Flink 中,数据源(Source)是其中一个核心组件,负责从各种来源读取数据供 Flink 程序处理。 Flink 的数据源类型丰富,涵盖了从简单测试到生产环境使用的各种场景。Kafka、Socket、文件和集合是 Flink 中最常见…

5.2 Go 参数传递

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

【傻呱呱】VirtualHere共享局域网中的USB设备(使用Pavadan老毛子固件搭建篇)

前期准备 SSH工具(FinalShell)老毛子固件路由器一台 搭建VirtualHere服务端 进入VirtualHere官网下载对应处理器架构的包,我的是RT-N14U-GPIO路由器刷的老毛子固件,这种一般选择最后一个或者倒数第二个包,这里我选择…

Transformers集成SwanLab实现AI训练可视化监控

🤗HuggingFace Transformers Hugging Face 的 Transformers 是一个非常流行的开源库,它提供了大量预训练的模型,主要用于自然语言处理(NLP)任务。这个库的目标是使最新的模型能够易于使用,并支持多种框架&…

Topogun 3 for Mac——您的专业三维模型处理利器

Topogun 3 for Mac,无疑是三维模型处理领域的翘楚。该软件不仅功能全面,而且操作简便,能够满足您对于三维模型处理的各种需求。 导入高模、视图操作、新建拓扑层,一切都在您的掌控之中。Topogun 3强大的自动拓扑功能,…

小猪APP分发:一站式免费应用推广的理想平台

在日益拥挤的移动应用市场中,对于独立开发者和新兴应用而言,找到一个高效且成本效益高的分发渠道至关重要。这正是小猪APP分发平台www.appzhu.cn脱颖而出的原因,它不仅提供了一个全面的解决方案,帮助开发者免费推广他们的应用程序…

前端基础入门三大核心之JS篇:解锁「穷举法」算法的奥秘【含代码示例】

前端基础入门三大核心之JS篇:解锁「穷举法」算法的奥秘【含代码示例】 穷举法基本概念及其作用什么是穷举法?作用说明 穷举法实战演练示例1:找出1到100之间的所有质数示例2:经典的数独求解性能优化与安全考量 实际工作中的技巧遇到…

家政预约小程序06服务展示

目录 1 首页展示2 团购详情总结 在家政小程序中,最重要的信息就是各项服务的内容。顾客通过服务的信息,了解家政公司可以提供什么样的服务以及相关的收费。本篇我们介绍一下服务展示功能如何开发。 1 首页展示 在首页我们已经开发了活动展示、服务分类展…

月入25000,因何焦虑?

遇到一位铁粉经常给我点赞评论,没勾兑之前还以为他赋闲在家,没想到收入很高,要是放在5年前相比很多人都不会这么焦虑,那个时候大环境很好,随便跳个槽收入至少能增长30%。 这位铁粉从事java开发,目前就职于某…

C++ 程序的基本要素

一 标识符 程序中变量、类型、函数和标号的名称称标识符。 a,b,name,int,char,main,void等。 系统已有的标识符称为关键字。 常见关键字 using,namespace,void,return; int,float,double,char,bool,signed,unsignex, long,short,const,true,false,sizeof if,else,for,do,whil…

Ollama + (Anythingllm / Open WebUI / MaxKB)搭建本地大模型

个人体验MaxKB做知识库效果最好 一、Ollama 1、下载Ollama 地址:Download Ollama on macOS curl -fsSL https://ollama.com/install.sh | sh 2、下载指定的模型 地址:library # Llama3 ollama run llama3:8b # 这个模型可以将文本内容转换成向量数…

统信UOS专业版操作系统如何安装惠普打印机驱动

通用集成驱动安装方法 以惠普P1566激光打印机为例介绍一下,在打印机管理器中选择打印机,手动选择安装驱动,找到品牌:惠普,型号:1566,安装驱动后测试打印;LaserJet Pro P1566 Foomati…

单细胞 10X 和seurat对象学习

单细胞seurat数据的基础知识 rm(list ls()) library(Seurat) #注意这个报错 #Warning: Feature names cannot have underscores (_), replacing with dashes (-) folderslist.files(./,pattern[123]$) folders scList lapply(folders,function(folder){ CreateSeuratObject(…

Docker打包之后如何将进行变成压缩包进行传输和使用?

假设现在有一个命令需要进行打包 docker build --platformlinux/amd64 -t md-cloud:24.05.27.2 . 下面详细解释一下 docker build: 这是 Docker 的命令,用于根据 Dockerfile 构建一个 Docker 镜像。 --platformlinux/amd64: 这个选项指定了构建镜像的目标平台。在这…

系统安全扫描扫出了:可能存在 CSRF 攻击怎么办

公司的H5在软件安全测试中被检查出可能存在 CSRF 攻击,网上找了一堆解决方法,最后用这种方式解决了。 1、问题描述 CSRF 是 Cross Site Request Forgery的缩写(也缩写为也就是在用户会话下对某个 CGI 做一些 GET/POST 的事,RIVTSTCNNARGO一这…

【VsCode】通过tasks.json中的problemMatcher属性的fileLocation子属性设定问题的输出内容

前言 这个问题是起因在我想把代码指向的相对路径更改为使用宏的绝对路径便于编译调试,但是在一次调试过程中有一个编译时报错,点击报错内容项时,却显示找不到路径文件。报错详细内容显示是 即:代码路径绝对路径。 "resourc…

Transformer详解(4)-前馈层残差连接层归一化

1、前馈层 前馈层接收自注意力层的输出作为输入。 from torch import nn import torch.nn.functional as Fclass FeedForward(nn.Module):def __init__(self, d_model512, d_ff2048, dropout0.1):super().__init__()# d_ff 默认设置为2048self.linear_1 nn.Linear(d_model,…

CentOS 7安装prometheus

说明:本文介绍如何在CentOS操作系统上安装prometheus Step1:下载安装包 访问Github仓库,下载对应版本的prometheus安装包 https://github.com/prometheus/prometheus/releases 操作系统的版本信息,可通过下面这两个命令查看&am…

C\C++语言中求由字符串构建的字符数组长度及所占字节数代码

【知识点】 在 C\C 语言中,由字符串构建的字符数组,以不可见字符 \0 作为结尾。\0 是字符串结束标志,不计入串长,但要占内存空间。 例如,若由字符串构建的字符数组为 s,则命令 strlen(s) 可得字符数组长度…

【UE Slate】 虚幻引擎Slate开发快速入门

目录 0 引言1 Slate框架1.0 控件布局1.1 SWidget1.1.1 SWidget的主要作用1.1.2 SWidget的关键方法1.1.3 使用SWidget创建自定义控件1.1.4 结论 1.2 SCompoundWidget1.2.1 SCompoundWidget的主要作用1.2.2 SCompoundWidget的使用示例1.2.3 SCompoundWidget的关系1.2.4 总结 1.3 …