CSS Module

CSS Module

什么是 CSS Module?

CSS Modules 不是官方规范或浏览器中的实现,而是构建步骤中的一个过程(在 Webpack 或 Browserify 的帮助下),它改变了类名和选择器的作用域(即有点像命名空间)。

目的:解决 CSS 中全局作用域的问题

开启 CSS Module

在 React 中默认开启了 CSS Module,样式表文件需要以 xxx.module.sass/less/css 命名。

作用域

默认Less或者CSS的规则是全局生效的,任何一个组件,只要有同名的className就会共用样式。

CSS Module可以有效避免作用域问题,它会生成一个唯一的标识作为className

全局作用域(:global)

修改第三方组件样式

:global(), 保证包裹的变量不受影响

如果我们想要修改第三方组件样式,默认情况通过css-module无法修改,需要添加:global才可以。

css 复制代码
.login {
  height: 100vh;
  background: url(/imgs/login_bg.jpeg) no-repeat;
  background-size: cover;
  background-position: center;
  :global(.title) {
    font-size: 42px;
    line-height: 1.5;
    text-align: center;
    margin-bottom: 30px;
  }
  :global(.ant-btn-primary) {
    background-color: red;
  }
}
相关推荐
鹘一几秒前
Prompts 组件实现
前端·javascript
大菜菜几秒前
Molecule Framework - ExplorerService API 详细文档
前端
_一两风4 分钟前
Vue-TodoList 项目详解
前端·javascript·vue.js
北辰alk4 分钟前
Vue中mixin与mixins:全面解析与实战指南
前端·vue.js
脾气有点小暴5 分钟前
UniApp实现刷新当前页面
开发语言·前端·javascript·vue.js·uni-app
YaeZed6 分钟前
Vue3-全局组件 && 递归组件
前端·vue.js
一只Viki7 分钟前
给 CS2 Major 竞猜做了个在线抄作业网站
前端
八点8 分钟前
Electron 应用中 Sharp 模块跨架构兼容性问题解决方案
前端
黑臂麒麟9 分钟前
DevUI modal 弹窗表单联动实战:表格编辑功能完整实现
前端·javascript·ui·angular.js
国服第二切图仔9 分钟前
DevUI Design中后台产品的开源前端解决方案之DataTable 表格组件核心解析
前端