webpack項目輕鬆混用css module

前言

本文講述css-loader開啓css模塊功能以後,如何與引用的npm包中樣式文件不產生衝突。
好比antd-mobilenpm包的引入。在不作特殊處理的前提下,樣式文件將會被轉譯成css module
javascript

1、產生問題的緣由

{ 
    test: /\.css$/,
    use: [
        'style-loader',
        {
            loader: 'css-loader',
            options: {
                modules: true,
                localIdentName: '[hash:base64:6]'
            }
        },
        'postcss-loader'
    ] 
}

以上代碼片斷,摘自webpack配置的module.rule
能夠看出wepack在編譯過程當中,遇到.css結尾的文件,都會交由postcss-loadercss-loaderstyle-loader依次處理。
由於css-loader開啓了css模塊功能,因此,全部通過處理的css文件,類名都將被改變。css

2、初步改進

使用excludeinclude進行區分java

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進行處理。node

2.單獨處理node_module內的css文件

{ 
    test: /\.css$/,
    use: [
        {
            loader: 'style-loader'
        },
        {
            loader: 'css-loader'
        },
        {
            loader: 'postcss-loader'
        }
    ],
    include:[path.resolve(__dirname, '..', 'node_modules')]
}

3、升級版,支持css module模式和普通模式混用

1.用文件名區分兩種模式

  • *.global.css 普通模式
  • *.css css module模式

這裏統一用 global 關鍵詞進行識別。webpack

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')]
}

4、其餘問題

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

相關文章
相關標籤/搜索