前言
本文讲述css-loader
开启css模块
功能之后,如何与引用的npm包中样式文件不产生冲突。
比如antd-mobile
npm包的引入。在不做特殊处理的前提下,样式文件将会被转译成css module
。
一、产生问题的原因
1 | { |
以上代码片段,摘自webpack
配置的module.rule
。
可以看出wepack
在编译过程中,遇到.css
结尾的文件,都会交由postcss-loader
、css-loader
和style-loader
依次处理。
因为css-loader
开启了css模块
功能,所以,所有经过处理的css
文件,类名都将被改变。
二、初步改进
使用
exclude
和include
进行区分
1.node_module
文件夹内的文件,避免被当前rule
处理
1 | { |
如上所示,将node_module
文件夹内的文件,用exclude
排除在外,不用当前rule
进行处理。
2.单独处理node_module
内的css文件
1 | { |
三、升级版,支持css module
模式和普通模式混用
1.用文件名区分两种模式
- *.global.css
普通模式
- *.css
css module模式
这里统一用 global
关键词进行识别。
2.用正则表达式匹配文件
1 | // css module |
四、其他问题
less
在使用css module
时,对url
的解析存在冲突,可以用resolve-url-loader
进行解决,直接上代码:
1 |
|