webpack项目轻松混用css module的方法


Posted in Javascript onJune 12, 2018

前言

本文讲述css-loader开启css模块功能之后,如何与引用的npm包中样式文件不产生冲突。

比如antd-mobilenpm包的引入。在不做特殊处理的前提下,样式文件将会被转译成css module

一、产生问题的原因

{ 
  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文件,类名都将被改变。

二、初步改进

使用exclude和include进行区分

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进行处理。

2.单独处理node_module内的css文件

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

三、升级版,支持css module模式和普通模式混用

1.用文件名区分两种模式

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

这里统一用 global 关键词进行识别。

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

参考

[1] [Updated README regarding relative filepaths issue #121]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js tab 选项卡
Apr 26 Javascript
JavaScript调用浏览器打印功能实例分析
Jul 17 Javascript
浅析AngularJS中的指令
Mar 20 Javascript
javascript实现的左右无缝滚动效果
Sep 19 Javascript
vue.js中$watch的用法示例
Oct 04 Javascript
JAVA Web实时消息后台服务器推送技术---GoEasy
Nov 04 Javascript
使用BootStrap实现悬浮窗口的效果
Dec 13 Javascript
JavaScript之DOM插入更新删除_动力节点Java学院整理
Jul 03 Javascript
在一个页面实现两个zTree联动的方法
Dec 20 Javascript
Node.js成为Web应用开发最佳选择的原因
Feb 05 Javascript
JavaScript同源策略和跨域访问实例详解
Apr 03 Javascript
解决vue+ element ui 表单验证有值但验证失败问题
Jan 16 Javascript
微信小程序js文件改变参数并在视图上及时更新【推荐】
Jun 11 #Javascript
用vue快速开发app的脚手架工具
Jun 11 #Javascript
详解React Native 屏幕适配(炒鸡简单的方法)
Jun 11 #Javascript
vue非父子组件通信问题及解决方法
Jun 11 #Javascript
Angular如何在应用初始化时运行代码详解
Jun 11 #Javascript
详解.vue文件解析的实现
Jun 11 #Javascript
vue filters的使用详解
Jun 11 #Javascript
You might like
JavaScript 编程引入命名空间的方法
2007/06/29 Javascript
JavaScript-世界上误解最深的语言分析
2007/08/12 Javascript
Javascript学习笔记5 类和对象
2010/01/11 Javascript
jQuery Select(单选) 模拟插件 V1.3.62 改进版
2010/07/17 Javascript
JS中获取数据库中的值的方法
2013/07/14 Javascript
js中的前绑定和后绑定详解
2013/08/01 Javascript
node.js中的fs.readSync方法使用说明
2014/12/17 Javascript
纯JavaScript实现的兼容各浏览器的添加和移除事件封装
2015/03/28 Javascript
javascript编写贪吃蛇游戏
2015/07/07 Javascript
Vue.js 和 MVVM 的注意事项
2016/11/07 Javascript
JS实现的适合做faq或menu滑动效果示例
2016/11/17 Javascript
Angular2自定义分页组件
2017/04/19 Javascript
Bootstrap fileinput文件上传预览插件使用详解
2017/05/16 Javascript
微信小程序视图template模板引用的实例详解
2017/09/20 Javascript
react-native android状态栏的实现
2018/06/15 Javascript
基于Vue实现可以拖拽的树形表格实例详解
2018/10/18 Javascript
JavaScript遍历数组的三种方法map、forEach与filter实例详解
2019/02/27 Javascript
Vue CLI3移动端适配(px2rem或postcss-plugin-px2rem)
2020/04/27 Javascript
Vue(定时器)解决mounted不能获取到data中的数据问题
2020/07/30 Javascript
vue.js+element 默认提示中英文操作
2020/11/11 Javascript
让python 3支持mysqldb的解决方法
2017/02/14 Python
Python3读取Excel数据存入MySQL的方法
2018/05/04 Python
win10 64bit下python NLTK安装教程
2018/09/19 Python
python微信好友数据分析详解
2018/11/19 Python
selenium使用chrome浏览器测试(附chromedriver与chrome的对应关系表)
2018/11/29 Python
python实现整数的二进制循环移位
2019/03/08 Python
详解Python的数据库操作(pymysql)
2019/04/04 Python
详解Python在使用JSON时需要注意的编码问题
2019/12/06 Python
PyCharm License Activation激活码失效问题的解决方法(图文详解)
2020/03/12 Python
Python如何绘制日历图和热力图
2020/08/07 Python
pyqt5 textEdit、lineEdit操作的示例代码
2020/08/12 Python
安全生产实施方案
2014/02/23 职场文书
幼儿老师求职信
2014/06/30 职场文书
党支部2014年度工作总结
2014/12/04 职场文书
企业宣传稿范文
2015/07/23 职场文书
nginx简单配置多个server的方法
2021/03/31 Servers