本文转载于:猿2048网站https://www.mk2048.com/blog/blog.php?id=ck2jahj&title=webpack%E9%A1%B9%E7%9B%AE%E8%BD%BB%E6%9D%BE%E6%B7%B7%E7%94%A8css+modulejavascript
本文讲述css-loader
开启css模块
功能以后,如何与引用的npm包中样式文件不产生冲突。
好比antd-mobile
npm包的引入。在不作特殊处理的前提下,样式文件将会被转译成css module
。
php
{ 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
文件,类名都将被改变。css
使用
exclude
和include
进行区分java
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
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
关键词进行识别。webpack
// 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
进行解决,直接上代码:git
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 #121github
本文转载于:猿2048➭https://www.mk2048.com/blog/blog.php?id=ck2jahj&title=webpack%E9%A1%B9%E7%9B%AE%E8%BD%BB%E6%9D%BE%E6%B7%B7%E7%94%A8css+moduleweb