這篇文章給大家介紹怎么在webpack項目中實現(xiàn)css與module的混用,內(nèi)容非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、小程序開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了巧家免費建站歡迎大家使用!
一、產(chǎn)生問題的原因
{ test: /\.css$/, use: [ 'style-loader', { loader: 'css-loader', options: { modules: true, localIdentName: '[hash:base64:6]' } }, 'postcss-loader' ] }
以上代碼片段,摘自webpack配置的module.rule。
可以看出wepack在編譯過程中,遇到.css結(jié)尾的文件,都會交由postcss-loader、css-loader和style-loader依次處理。
因為css-loader開啟了css模塊功能,所以,所有經(jīng)過處理的css文件,類名都將被改變。
二、初步改進
使用exclude和include進行區(qū)分
1.node_module文件夾內(nèi)的文件,避免被當(dāng)前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文件夾內(nèi)的文件,用exclude排除在外,不用當(dāng)前rule進行處理。
2.單獨處理node_module內(nèi)的css文件
{ test: /\.css$/, use: [ { loader: 'style-loader' }, { loader: 'css-loader' }, { loader: 'postcss-loader' } ], include:[path.resolve(__dirname, '..', 'node_modules')] }
三、升級版,支持css module模式和普通模式混用
1.用文件名區(qū)分兩種模式
*.global.css 普通模式
*.css css module模式
這里統(tǒng)一用 global 關(guān)鍵詞進行識別。
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 } } ]
關(guān)于怎么在webpack項目中實現(xiàn)css與module的混用就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。