webpack项目轻松混用css module
2021-03-07 15:29
标签:pack pull 升级版 nbsp lob port com 前言 如何 本文讲述 以上代码片段,摘自 使用 如上所示,将 这里统一用 [1] Updated README regarding relative filepaths issue #121 webpack项目轻松混用css module 标签:pack pull 升级版 nbsp lob port com 前言 如何 原文地址:https://www.cnblogs.com/jkr666666/p/12885956.html前言
css-loader
开启css模块
功能之后,如何与引用的npm包中样式文件不产生冲突。
比如antd-mobile
npm包的引入。在不做特殊处理的前提下,样式文件将会被转译成css module
。一、产生问题的原因
{
test: /\.css$/,
use: [
‘style-loader‘,
{
loader: ‘css-loader‘,
options: {
modules: true,
localIdentName: ‘[hash:base64:6]‘
}
},
‘postcss-loader‘
]
}
webpack
配置的module.rule
。
可以看出wepack
在编译过程中,遇到.css
结尾的文件,都会交由postcss-loader
、css-loader
和style-loader
依次处理。
因为css-loader
开启了css模块
功能,所以,所有经过处理的css
文件,类名都将被改变。二、初步改进
exclude
和include
进行区分1.
node_module
文件夹内的文件,避免被当前rule
处理{
test: /\.css$/,
use: [
{
loader: ‘style-loader‘
},
{
loader: ‘css-loader‘,
options: {
modules: true,
localIdentName: ‘[hash:base64:6]‘
}
},
{
loader: ‘postcss-loader‘
}
],
exclude:[path.resolve(__dirname, ‘..‘, ‘node_modules‘)]
}
node_module
文件夹内的文件,用exclude
排除在外,不用当前rule
进行处理。2.单独处理
node_module
内的css文件{
test: /\.css$/,
use: [
{
loader: ‘style-loader‘
},
{
loader: ‘css-loader‘
},
{
loader: ‘postcss-loader‘
}
],
include:[path.resolve(__dirname, ‘..‘, ‘node_modules‘)]
}
三、升级版,支持
css module
模式和普通模式混用1.用文件名区分两种模式
普通模式
css module模式
global
关键词进行识别。2.用正则表达式匹配文件
// css module
{
test: new RegExp(`^(?!.*\\.global).*\\.css`),
use: [
{
loader: ‘style-loader‘
},
{
loader: ‘css-loader‘,
options: {
modules: true,
localIdentName: ‘[hash:base64:6]‘
}
},
{
loader: ‘postcss-loader‘
}
],
exclude:[path.resolve(__dirname, ‘..‘, ‘node_modules‘)]
}
// 普通模式
{
test: new RegExp(`^(.*\\.global).*\\.css`),
use: [
{
loader: ‘style-loader‘
},
{
loader: ‘css-loader‘,
},
{
loader: ‘postcss-loader‘
}
],
exclude:[path.resolve(__dirname, ‘..‘, ‘node_modules‘)]
}
四、其他问题
less
在使用css module
时,对url
的解析存在冲突,可以用resolve-url-loader
进行解决,直接上代码:
test: /\.less/,
use: [
{
loader: "style-loader"
},
{
loader: "css-loader",
options: {
sourceMap: true,
importLoaders: 2
}
},
{
loader: "postcss-loader",
options: {
sourceMap: true
}
},
{
loader: "resolve-url-loader",
options: {
sourceMap: true
}
},
{
loader: "less-loader",
options: {
sourceMap: true
}
}
]
参考
上一篇:kubernetes学习系列安装篇--第一篇:环境准备
下一篇:论文翻译:Deep Convolutional Capsule Network for Hyperspectral Image Spectral and Spectral-Spatial Classi