标签:pack pull 升级版 nbsp lob port com 前言 如何
本文讲述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
进行区分
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
进行处理。
node_module
内的css文件{
test: /\.css$/,
use: [
{
loader: ‘style-loader‘
},
{
loader: ‘css-loader‘
},
{
loader: ‘postcss-loader‘
}
],
include:[path.resolve(__dirname, ‘..‘, ‘node_modules‘)]
}
css module
模式和普通模式混用普通模式
css module模式
这里统一用 global
关键词进行识别。
// 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
}
}
]
[1] Updated README regarding relative filepaths issue #121
标签:pack pull 升级版 nbsp lob port com 前言 如何
原文地址:https://www.cnblogs.com/jkr666666/p/12885956.html