欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

webpack項(xiàng)目輕松混用css module的方法

 更新時(shí)間:2018年06月12日 08:38:13   作者:wall''s  
這篇文章主要介紹了webpack項(xiàng)目輕松混用css module的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

前言

本文講述css-loader開(kāi)啟css模塊功能之后,如何與引用的npm包中樣式文件不產(chǎn)生沖突。

比如antd-mobilenpm包的引入。在不做特殊處理的前提下,樣式文件將會(huì)被轉(zhuǎn)譯成css module。

一、產(chǎn)生問(wèn)題的原因

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

以上代碼片段,摘自webpack配置的module.rule。

可以看出wepack在編譯過(guò)程中,遇到.css結(jié)尾的文件,都會(huì)交由postcss-loader、css-loader和style-loader依次處理。

因?yàn)閏ss-loader開(kāi)啟了css模塊功能,所以,所有經(jīng)過(guò)處理的css文件,類名都將被改變。

二、初步改進(jìn)

使用exclude和include進(jìn)行區(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進(jìn)行處理。

2.單獨(dú)處理node_module內(nèi)的css文件

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

三、升級(jí)版,支持css module模式和普通模式混用

1.用文件名區(qū)分兩種模式

  1. *.global.css 普通模式
  2. *.css css module模式

這里統(tǒng)一用 global 關(guān)鍵詞進(jìn)行識(shí)別。

2.用正則表達(dá)式匹配文件

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

四、其他問(wèn)題

less在使用css module時(shí),對(duì)url的解析存在沖突,可以用resolve-url-loader進(jìn)行解決,直接上代碼:

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]

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論